

# INDUCTION TRAINING EXERCISE - HLD DESIGN

| Template ID | VIAS_T01_00_006 |
|-------------|-----------------|
| Reference   |                 |
| Version     | 1.3             |
| Status      | Draft           |
| Author      | Mahmoud SHALABY |
| Date        | 30/5/2012       |

| Name          | Department | Title           | Date      |  |
|---------------|------------|-----------------|-----------|--|
| Approved by:  |            |                 |           |  |
| Amr ABDELNABY | Training   | Training Leader | 30/5/2012 |  |
| Reviewed by:  |            |                 |           |  |
| Amr ABDELNABY | Training   | Training Leader | 30/5/2012 |  |



## **Document History**

| Revision | Status | Date       | Author    | Changes                                                                                                                                                                                                                                                                       |
|----------|--------|------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1.0      | Draft  | 19/04/2012 | M.Shalaby | - Initial version                                                                                                                                                                                                                                                             |
| 1.1      | Draft  | 15/05/2012 | M.Shalaby | <ul> <li>Removed Instruction Page</li> <li>Updated assignation attribute for requirements in 3.3</li> <li>Updated section 4 - Design Constraints</li> <li>Filled in section 5.1 and 5.2</li> </ul>                                                                            |
| 1.2      | Draft  | 16/05/2012 | M.Shalaby | <ul> <li>Filled in section 5.3 (note: section 5.4 remaining)</li> <li>Filled in section 7 (note: 7.1.5 remaining)</li> <li>Defined all subsystem (section 8)</li> <li>Filled in section 8.2 (HAL subsystem)</li> </ul>                                                        |
| 1.3      | Draft  | 17/05/2012 | M.Shalaby | <ul> <li>Modified the location of the HIF/TIF components</li> <li>Filled in section remaining of section 8</li> <li>Filled in sections 5.4 and 7.1.5</li> <li>Sections 5 and 7.1 are to be revisited</li> <li>Section 7.2.3 Interface Design needs to be revisited</li> </ul> |



## **Table of Contents**

| D | OCUME  | ENT HISTORY                               | 2  |
|---|--------|-------------------------------------------|----|
| T | ABLE C | PF CONTENTS                               | 3  |
| 1 | INTE   | RODUCTION                                 | 5  |
|   | 1.1    | DOCUMENT SCOPE                            | 5  |
|   | 1.2    | GOALS AND OBJECTIVES                      | _  |
|   | 1.3    | DESIGN METHODOLOGY AND STANDARDS          |    |
|   | 1.4    | REFERENCE DOCUMENTS                       |    |
| 2 | TER    | MS AND ABBREVIATIONS                      | 7  |
| 3 | SYS    | TEM DESCRIPTION                           | 8  |
|   | 3.1    | Overview                                  | 8  |
|   | 3.2    | SOFTWARE CONTEXT DIAGRAM                  | 8  |
|   | 3.3    | SOFTWARE EXTERNAL INTERFACES              |    |
| 4 | DES    | IGN CONSTRAINTS                           | 11 |
|   | 4.1    | CONSTRAINTS ON INITIALIZATION             | 11 |
|   | 4.2    | CONSTRAINTS ON INPUTS                     | 11 |
|   | 4.3    | CONSTRAINTS ON OUTPUTS                    | 11 |
|   | 4.4    | HARDWARE CONSTRAINTS & DEPENDENCIES       | 11 |
|   | 4.5    | COMMUNICATION/NETWORK CONSTRAINTS         | 12 |
|   | 4.6    | DIAGNOSTIC CONSTRAINTS                    | 12 |
|   | 4.7    | DIMENSIONING CONSTRAINTS                  | 12 |
| 5 | REA    | L TIME ANALYSIS                           | 13 |
|   | 5.1    | PROCESSES IDENTIFICATION                  | 13 |
|   | 5.2    | TIMING BASES IDENTIFICATION               | 13 |
|   | 5.3    | SOFTWARE OPERATING MODES                  | 14 |
|   | 5.4    | SHARED RESOURCES                          | 15 |
|   | 5.4.1  | Hardware Resources                        | 15 |
|   | 5.4.2  | 2 Software Resources                      | 15 |
| 6 | DES    | IGN ALTERNATIVES AND JUSTIFICATION        | 16 |
| 7 | ARC    | CHITECTURAL DESIGN                        | 17 |
|   | 7.1    | REAL TIME ARCHITECTURE                    | 17 |
|   | 7.1.1  | I Interrupts                              | 17 |
|   | 7.1.2  | 2 Cyclic Tasks                            | 17 |
|   | 7.1.3  | B Event-triggered Tasks                   | 17 |
|   | 7.1.4  | Estimated Workload                        | 17 |
|   | 7.1.5  | Shared Resources Protection               | 17 |
|   | 7.1.6  | Dynamic Architecture Requirements         | 18 |
|   | 7.2    | STATIC ARCHITECTURE (INTERNAL INTERFACES) | 20 |
|   | 7.2.1  | Layered Architecture                      | 20 |
|   | 7.2.2  | 2 Components Design                       | 20 |
|   | 7.2.3  | B Interfaces Design                       | 21 |

Page 3/48

## <u>Valeo</u>

#### **Induction Training Exercise - HLD Design**

Version 1.3

|    | 7.2.4     | Subsystems                   | 21 |
|----|-----------|------------------------------|----|
|    | 7.3 MEN   | MORY CONSUMPTION             | 21 |
|    | 7.3.1     | Memory Size                  | 21 |
|    | 7.3.2     | Memory Map                   | 21 |
| 8  | SOFTWA    | ARE COMPONENTS               | 22 |
|    | 8.1 MC/   | AL SUBSYSTEM                 | 22 |
|    | 8.1.1     | DIO Component                | 22 |
|    | 8.1.2     | MCU Component                | 24 |
|    | 8.1.3     | PORT Component               | 26 |
|    | 8.2 HAL   | _ SUBSYSTEM                  | 28 |
|    | 8.2.1     | SSD Component                | 28 |
|    | 8.2.2     | PBD Component                | 32 |
|    | 8.3 APF   | P SUBSYSTEM                  | 35 |
|    | 8.3.1     | HIF Component                | 35 |
|    | 8.3.2     | TIF Component                | 37 |
|    | 8.3.3     | MODE Component               | 40 |
|    | 8.3.4     | SCHED Component              | 43 |
| 9  | SEQUEN    | NCE MANAGEMENT               | 47 |
|    | 9.1 INITI | IALIZATION SEQUENCE          | 47 |
|    | 9.2 SEQ   | QUENCE DIAGRAMS              | 47 |
| 10 | SOFT      | WARE INTEGRATION CONSTRAINTS | 48 |



#### 1 Introduction

This section provides an overview of the entire design document. It should introduce the reader to the system/software and set the context for the rest of the document.

#### 1.1 Document Scope

This document is the High Level Design Document for project Induction Training Exercise identified by VALEO project identifier INDUC.

The software high-level/global design activity defines for a software project:

- The real time constraints on the project (issued from upstream requirements or defined during the global design),
- The software hypothesis and choices taken to respect these constraints,
- The shared data identification and the associated protection mechanisms,
- The software static and dynamic architecture.

This document contains separate parts:

- The software real-time constraints collection: Identification and classification of all realtime constraints issued from upstream requirements (project, product, hardware, COTS, standard components).
- The real-time analysis:
  - Association between the previous real-time constraints and the SA-RT functions,
  - Design hypothesis and choices (according to the constraints association) in order to identify the necessary tasks and Interrupts,
  - o The dynamic architecture with detailed tasks, interrupts and treatments description,
  - o The shared data identification and the associated protection mechanisms.
- The static design:
  - o The software static architecture,
  - o The treatments allocation in components,
  - The dataflow diagrams,
  - o The components description.

This part is completed by the detailed design of components/modules.



## 1.2 Goals and Objectives

The software described in this document is a simulation to the TCM ECU present in most of the modern vehicles and is part of the induction training exercise given at VALEO Egypt. It simulates the basic functionalities of the TCM (right blinker, left blinker and hazard blinker —which is also called double flasher in common language) through blinking 2 SSDs attached to the system.

### 1.3 Design Methodology and Standards

| # | Document Name                       | Reference           | Version |
|---|-------------------------------------|---------------------|---------|
| 1 | Coding Rules                        | GEI-RD-H01-0000-095 | 1.10    |
| 2 | Source Code Naming Rules Guidelines | GEI-RD-H01-0000-094 | 1.5     |
| 3 | SW Design Guide                     | GEI-RD-H01-0000-081 | G       |
| 4 | Source Code Appearance Rules        | GEI-RD-H01-0000-096 | 1.0     |

#### 1.4 Reference Documents

| # | Document Name                       | Reference                 | Version      |
|---|-------------------------------------|---------------------------|--------------|
| 1 | Software Development Plan*          | N/A*                      | N/A*         |
| 2 | Software Requirements Specification | SRS Induction.doc         | 1.0          |
| 3 | Hardware Software Interface         | Controller Data Sheet.pdf | Rev 3 1/2009 |

<sup>\*</sup> Software Development Plan (SDP) is not applicable for induction training as this HLD is only for demonstration purposes.



## 2 Terms and Abbreviations

| Abbreviation | Description                                          |
|--------------|------------------------------------------------------|
| VIAS         | Valeo Inter-branch Automotive Software (VALEO Egypt) |
| CEE          | Center for Electronics Excellence                    |
| HW           | Hardware                                             |
| SW           | Software                                             |
| HIS          | Hardware/Software Interface                          |
| ECU          | Electronic Control Unit                              |
| TCM          | Top Column Module                                    |
| SSD          | Seven Segment Display                                |
| РВ           | Push Button                                          |



## 3 System Description

#### 3.1 Overview



Figure 1 - System Overview

The purpose of this system is to simulate the following features of the TCM ECU:

- Left Blinker
- Right Blinker
- Hazards Blinkers (double flasher)

The simulation of the TCM arms is done using three push buttons, two of them are simulating that the arm is moved one step up or down to identify the blinking state and the third simulates pressing on the hazards button present in the vehicle.

For more details about the system's overview, refer to REF2; section 2.1.

### 3.2 Software Context Diagram

Refer to REF2; Figure 2 – Software External Interfaces for more details.



## 3.3 Software External Interfaces

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | nal Name                                                                                                                                                                                                                                                                                             | Source                                                                                                      | ce/Destination                                                                                                                                                                                                                                                                                                                      | Physical Pin                                                                                                                                                        |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                      |                                                                                                             | Chara                                                                                                                                                                                                                                                                                                                               | cteristics                                                                                                                                                          |
| {H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | LD-0001(0)}                                                                                                                                                                                                                                                                                          |                                                                                                             | {Covers: SRS-0                                                                                                                                                                                                                                                                                                                      | 001(0)}                                                                                                                                                             |
| {Assignation: PORT}                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | {Test Method: Component Test}                                                                                                                                                                                                                                                                        | {Integr                                                                                                     | ation Phase: }                                                                                                                                                                                                                                                                                                                      | {Justification: }                                                                                                                                                   |
| PE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | B_PRESS2                                                                                                                                                                                                                                                                                             | STEP_DO                                                                                                     | WN_PB Push Button                                                                                                                                                                                                                                                                                                                   | PTG1 [Pin №22]                                                                                                                                                      |
| he signal issued by STEF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | P_DOWN_PB (Press2) Push Button                                                                                                                                                                                                                                                                       |                                                                                                             | Type: Digital Input Properties: (1 → ON,                                                                                                                                                                                                                                                                                            | 0 → OFF)                                                                                                                                                            |
| {H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | LD-0002(0)}                                                                                                                                                                                                                                                                                          |                                                                                                             | {Covers: SRS-0                                                                                                                                                                                                                                                                                                                      | 002(0)}                                                                                                                                                             |
| {Assignation: PORT}                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | {Test Method: Component Test}                                                                                                                                                                                                                                                                        | {Integr                                                                                                     | ation Phase: }                                                                                                                                                                                                                                                                                                                      | {Justification: }                                                                                                                                                   |
| PE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | B_PRESS3                                                                                                                                                                                                                                                                                             | STEP_U                                                                                                      | P_PB Push Button                                                                                                                                                                                                                                                                                                                    | PTG2 [Pin №34]                                                                                                                                                      |
| he signal issued by STEF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | P_UP_PB (Press3) Push Button                                                                                                                                                                                                                                                                         |                                                                                                             | Type: Digital Input Properties: (1 → ON,                                                                                                                                                                                                                                                                                            | 0 → OFF)                                                                                                                                                            |
| {H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | LD-0003(0)}                                                                                                                                                                                                                                                                                          |                                                                                                             | {Covers: SRS-0                                                                                                                                                                                                                                                                                                                      | 003(0)}                                                                                                                                                             |
| {Assignation: PORT}                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | {Test Method: Component Test}                                                                                                                                                                                                                                                                        | {Integr                                                                                                     | ation Phase: }                                                                                                                                                                                                                                                                                                                      | {Justification: }                                                                                                                                                   |
| PE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | B_PRESS4                                                                                                                                                                                                                                                                                             | HAZARD_                                                                                                     | UP_PB Push Button                                                                                                                                                                                                                                                                                                                   | PTG3 [Pin Nº35]                                                                                                                                                     |
| he signal issued by HAZZ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ZARD_PB (Press4) Push Button                                                                                                                                                                                                                                                                         |                                                                                                             | Type: Digital Input Properties: (1 → ON,                                                                                                                                                                                                                                                                                            | 0 <del>→</del> OFF)                                                                                                                                                 |
| {H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | LD-0004(0)}                                                                                                                                                                                                                                                                                          |                                                                                                             | {Covers: SRS-0                                                                                                                                                                                                                                                                                                                      | 004(0)}                                                                                                                                                             |
| {Assignation: PORT}                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | {Test Method: Component Test}                                                                                                                                                                                                                                                                        | {Integr                                                                                                     | ation Phase: }                                                                                                                                                                                                                                                                                                                      | {Justification: }                                                                                                                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | SS_A                                                                                                                                                                                                                                                                                                 |                                                                                                             | AFF1/AFF2                                                                                                                                                                                                                                                                                                                           | PTB0 [Pin Nº23]                                                                                                                                                     |
| SDs, RIGHT_SIGNAL_SS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | nicro-controller to control segment D (AFF1) and LEFT_SIGNAL_SSD                                                                                                                                                                                                                                     |                                                                                                             | Properties: (1 → ON,                                                                                                                                                                                                                                                                                                                | · · · · · · · · · · · · · · · · · · ·                                                                                                                               |
| {Assignation: PORT}                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | LD-0005(0)}  {Test Method: Component Test}                                                                                                                                                                                                                                                           | Untogr                                                                                                      | {Covers: SRS-0                                                                                                                                                                                                                                                                                                                      | 005(0)}<br>{Justification: }                                                                                                                                        |
| {Assignation. FOR1}                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | SS B                                                                                                                                                                                                                                                                                                 |                                                                                                             | ation Phase: } AFF1/AFF2                                                                                                                                                                                                                                                                                                            | PTB1 [Pin Nº24]                                                                                                                                                     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | micro-controller to control segmer<br>SD (AFF1) and LEFT_SIGNAL_SSI                                                                                                                                                                                                                                  |                                                                                                             | Type: Digital Output Properties: (1 → ON,                                                                                                                                                                                                                                                                                           | ·                                                                                                                                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | I D-0006(0))                                                                                                                                                                                                                                                                                         |                                                                                                             | (Covers, SBS-0)                                                                                                                                                                                                                                                                                                                     | nne(n))                                                                                                                                                             |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | LD-0006(0)} {Test Method: Component Test}                                                                                                                                                                                                                                                            | {Integr                                                                                                     | {Covers: SRS-0                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | {Test Method: Component Test}                                                                                                                                                                                                                                                                        |                                                                                                             | ation Phase: }                                                                                                                                                                                                                                                                                                                      | {Justification: }                                                                                                                                                   |
| {Assignation: PORT}                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                      | "c" of the 2                                                                                                | ation Phase: } AFF1/AFF2                                                                                                                                                                                                                                                                                                            | {Justification: } PTB2 [Pin Nº25]                                                                                                                                   |
| {Assignation: PORT} he signal issued by the mSDs, RIGHT_SIGNAL_SS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | {Test Method: Component Test}   SS_C                                                                                                                                                                                                                                                                 | "c" of the 2<br>(AFF2).                                                                                     | ation Phase: }  AFF1/AFF2  Type: Digital Output  Properties: (1 → ON,                                                                                                                                                                                                                                                               | {Justification: }  PTB2 [Pin №25]  0 → OFF)  007(0)}                                                                                                                |
| {Assignation: PORT} he signal issued by the mSDs, RIGHT_SIGNAL_SS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | {Test Method: Component Test}  SS_C nicro-controller to control segment D (AFF1) and LEFT_SIGNAL_SSD                                                                                                                                                                                                 | "c" of the 2<br>(AFF2).                                                                                     | ation Phase: }  AFF1/AFF2  Type: Digital Output  Properties: (1 → ON,                                                                                                                                                                                                                                                               | {Justification: } PTB2 [Pin №25]  0 → OFF)                                                                                                                          |
| {Assignation: PORT} The signal issued by the material SDs, RIGHT_SIGNAL_SS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | {Test Method: Component Test}   SS_C                                                                                                                                                                                                                                                                 | "c" of the 2 (AFF2).                                                                                        | ation Phase: }  AFF1/AFF2  Type: Digital Output  Properties: (1 → ON,                                                                                                                                                                                                                                                               | {Justification: }  PTB2 [Pin №25]  0 → OFF)  007(0)}  {Justification: }                                                                                             |
| {Assignation: PORT} The signal issued by the meson of the signal issued by | {Test Method: Component Test}  SS_C  nicro-controller to control segment D (AFF1) and LEFT_SIGNAL_SSD (  LD-0007(0)}  {Test Method: Component Test}                                                                                                                                                  | "c" of the 2 (AFF2).                                                                                        | ation Phase: }  AFF1/AFF2  Type: Digital Output  Properties: (1 → ON,  {Covers: SRS-0 ation Phase: }  AFF1/AFF2                                                                                                                                                                                                                     | {Justification: }  PTB2 [Pin №25]  0 → OFF)  007(0)}  {Justification: }  PTB3 [Pin №26]                                                                             |
| {Assignation: PORT} The signal issued by the meson of the signal issued by | {Test Method: Component Test}   SS_C     Dicro-controller to control segment     D (AFF1) and LEFT_SIGNAL_SSD     LD-0007(0)}   {Test Method: Component Test}   SS_D     micro-controller to control segment     SD (AFF1) and LEFT_SIGNAL_SSI     LD-0008(0)}                                       | "c" of the 2 (AFF2).  {Integr  out "d" of the D (AFF2).                                                     | ation Phase: }  AFF1/AFF2  Type: Digital Output Properties: (1 → ON,  {Covers: SRS-0 ation Phase: }  AFF1/AFF2  Type: Digital Output Properties: (1 → ON,  {Covers: SRS-0                                                                                                                                                           | {Justification: }  PTB2 [Pin №25]  0 → OFF)  007(0)}  {Justification: }  PTB3 [Pin №26]  0 → OFF)                                                                   |
| {Assignation: PORT} The signal issued by the mesons, RIGHT_SIGNAL_SS  {Hear (Assignation: PORT) The signal issued by the mesons, RIGHT_SIGNAL_S                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | {Test Method: Component Test}   SS_C     Dicro-controller to control segment     D (AFF1) and LEFT_SIGNAL_SSD     LD-0007(0)}   {Test Method: Component Test}   SS_D     micro-controller to control segment     SSD (AFF1) and LEFT_SIGNAL_SSI                                                      | "c" of the 2 (AFF2).  {Integr  out "d" of the D (AFF2).                                                     | Type: Digital Output Properties: (1 → ON,  {Covers: SRS-0 ation Phase: }  AFF1/AFF2  Type: Digital Output Properties: (1 → ON,                                                                                                                                                                                                      | {Justification: }  PTB2 [Pin №25]  0 → OFF)  007(0)}  {Justification: }  PTB3 [Pin №26]  0 → OFF)                                                                   |
| {Assignation: PORT}  he signal issued by the mSDs, RIGHT_SIGNAL_SS  {H {Assignation: PORT}  he signal issued by the mSDs, RIGHT_SIGNAL_S                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | {Test Method: Component Test}   SS_C     Dicro-controller to control segment     D (AFF1) and LEFT_SIGNAL_SSD     LD-0007(0)}   {Test Method: Component Test}   SS_D     micro-controller to control segment     SD (AFF1) and LEFT_SIGNAL_SSI     LD-0008(0)}                                       | (AFF2).  {Integr  of the 2 (AFF2).  {Integr                                                                 | ation Phase: }  AFF1/AFF2  Type: Digital Output Properties: (1 → ON,  {Covers: SRS-0 ation Phase: }  AFF1/AFF2  Type: Digital Output Properties: (1 → ON,  {Covers: SRS-0                                                                                                                                                           | {Justification: }  PTB2 [Pin №25]  0 → OFF)  007(0)}  {Justification: }  PTB3 [Pin №26]  0 → OFF)  008(0)}                                                          |
| {Assignation: PORT} The signal issued by the mesons, RIGHT_SIGNAL_SS  {H {Assignation: PORT} The signal issued by the mesons, RIGHT_SIGNAL_S  {H {Assignation: PORT}  The signal issued by the mesons of the signal issued by the  | {Test Method: Component Test}   SS_C     Conicro-controller to control segment     D (AFF1) and LEFT_SIGNAL_SSD     LD-0007(0)}     {Test Method: Component Test}   SS_D     micro-controller to control segment     SD (AFF1) and LEFT_SIGNAL_SSI     LD-0008(0)}     {Test Method: Component Test} | "c" of the 2 (AFF2).  {Integr  of the D (AFF2).  {Integr  if "d" of the D (AFF2).  {Integr  if "e" of the 2 | ation Phase: }  AFF1/AFF2  Type: Digital Output Properties: (1 → ON,  {Covers: SRS-0 ation Phase: }  AFF1/AFF2  Type: Digital Output Properties: (1 → ON,  {Covers: SRS-0 ation Phase: }                                                                                                                                            | {Justification: }  PTB2 [Pin №25]  0 → OFF)  007(0)}  {Justification: }  PTB3 [Pin №26]  0 → OFF)  008(0)}  {Justification: }  PTE4 [Pin №12]                       |
| {Assignation: PORT} The signal issued by the meson of the signal issued by | Test Method: Component Test                                                                                                                                                                                                                                                                          | (AFF2).  (Integrate of the D (AFF2).  (Integrate of the D (AFF2).  (Integrate of the 2 (AFF2).              | ation Phase: }  AFF1/AFF2  Type: Digital Output Properties: (1 → ON,  {Covers: SRS-0 ation Phase: }  AFF1/AFF2  Type: Digital Output Properties: (1 → ON,  {Covers: SRS-0 ation Phase: }  AFF1/AFF2  Type: Digital Output Properties: (1 → ON,  {Covers: SRS-0 ation Phase: }  AFF1/AFF2  Type: Digital Output Properties: (1 → ON, | {Justification: }  PTB2 [Pin N°25]  0 → OFF)  007(0)}  {Justification: }  PTB3 [Pin N°26]  0 → OFF)  008(0)}  {Justification: }  PTE4 [Pin N°12]  0 → OFF)  009(0)} |
| {Assignation: PORT}  The signal issued by the most of the signal i | Test Method: Component Test                                                                                                                                                                                                                                                                          | (AFF2).  (Integrate of the D (AFF2).  (Integrate of the D (AFF2).  (Integrate of the 2 (AFF2).              | ation Phase: }  AFF1/AFF2  Type: Digital Output Properties: (1 → ON,  {Covers: SRS-0 ation Phase: }  AFF1/AFF2  Type: Digital Output Properties: (1 → ON,  {Covers: SRS-0 ation Phase: }  AFF1/AFF2  Type: Digital Output Properties: (1 → ON,                                                                                      | {Justification: }  PTB2 [Pin №25]  0 → OFF)  007(0)}  {Justification: }  PTB3 [Pin №26]  0 → OFF)  008(0)}  {Justification: }  PTE4 [Pin №12]  0 → OFF)             |



#### **Induction Training Exercise - HLD Design**

Version 1.3

| {IIL                                                         | D-0010(0)}                                                            |           | (Covers: SI                                               | RS-0010(0)}                                     |
|--------------------------------------------------------------|-----------------------------------------------------------------------|-----------|-----------------------------------------------------------|-------------------------------------------------|
| {Assignation: PORT}                                          | {Test Method: Component Test}                                         | {Integra  | ation Phase: }                                            | {Justification: }                               |
|                                                              | SS_G                                                                  | A         | AFF1/AFF2                                                 | PTE6 [Pin Nº14]                                 |
|                                                              | icro-controller to control segmen<br>D (AFF1) and LEFT_SIGNAL_SSD     | •         | Type: Digital Outp                                        |                                                 |
| {HL                                                          | D-0011(0)}                                                            |           | {Covers: SI                                               | RS-0011(0)}                                     |
| {Assignation: PORT}                                          | {Test Method: Component Test}                                         | {Integra  | ation Phase: }                                            | {Justification: }                               |
| S                                                            | S_DOT                                                                 |           | AFF1/AFF2                                                 | PTE7 [Pin Nº15]                                 |
|                                                              | D-0012(0)}                                                            |           | (Covers: SI                                               | RS-0012(0)}                                     |
| (A                                                           |                                                                       |           |                                                           |                                                 |
| {Assignation: PORT}                                          | {Test Method: Component Test}                                         | {Integra  | ation Phase: }                                            | {Justification: }                               |
| S                                                            | S_SEG1<br>nicro-controller to enable/disable                          | , ,       | AFF1                                                      | PTB4 [Pin Nº27]                                 |
| St<br>The signal issued by the r<br>Segment Display RIGHT_SI | S_SEG1<br>nicro-controller to enable/disable                          | , ,       | AFF1 Type: Digital Out                                    | PTB4 [Pin N°27]  out  ON, 0 → OFF)              |
| St<br>The signal issued by the r<br>Segment Display RIGHT_SI | S_SEG1<br>nicro-controller to enable/disable<br>GNAL_SSD (AFF1).      | the Seven | AFF1  Type: Digital Outp                                  | PTB4 [Pin N°27]  out  ON, 0 → OFF)              |
| SS The signal issued by the modern Display RIGHT_SIGNAT  {   | S_SEG1 nicro-controller to enable/disable GNAL_SSD (AFF1). D-0013(0)} | the Seven | AFF1  Type: Digital Outp  Properties: (1 → 0  {Covers: Si | PTB4 [Pin N°27]  out  DN, 0 → OFF)  RS-0013(0)} |

Table 1 - Software External Interfaces



## 4 Design Constraints

#### 4.1 Constraints on Initialization

None

## 4.2 Constraints on Inputs

| Constraint ID | Description                                                                                                                                                  | Constraint Type | Value |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------|
| [INP_1]       | For the HAZARD_PB, the input signal is considered valid once it is <u>released</u> after being pressed for at least 200ms (signal stabilization time).       | Interval        | 200ms |
| [INP_2]       | For STEP_DOWN_PB and STEP_UP_PB, the input signal is considered valid once it is released after being pressed for at least 10ms (signal stabilization time). | Interval        | 10ms  |

Table 2 - Input Constraints

## 4.3 Constraints on Outputs

| Constraint ID | Description                                                                                                          | Constraint Type  | Value         |
|---------------|----------------------------------------------------------------------------------------------------------------------|------------------|---------------|
| [OUT_1]       | The SSDs controlled must be switched ON for 200ms ± 5 ms if the system is in either the LEFT or RIGHT blink states.  | Period<br>Jitter | 200ms<br>±5ms |
| [OUT_2]       | The SSDs controlled must be switched OFF for 300ms ± 5 ms if the system is in either the LEFT or RIGHT blink states. | Period<br>Jitter | 300ms<br>±5ms |
| [OUT_3]       | The SSDs controlled must be switched ON for 200ms ± 5 ms if the system is in the HAZARD blink state.                 | Period<br>Jitter | 200ms<br>±5ms |
| [OUT_4]       | The SSDs controlled must be switched OFF for 400ms ± 5 ms if the system is in the HAZARD blink state.                | Period<br>Jitter | 400ms<br>±5ms |

Table 3 - Output Constraints

## 4.4 Hardware Constraints & Dependencies

| Constraint ID | Description                                                                                                                                          | Туре          |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| [HW_1]        | The software shall initialize and configure the PLL to obtain 24 MHz bus frequency taking into consideration that the oscillator frequency is 4 MHz. | PLL           |
| [HW_2]        | The microcontroller ports should be configured as digital input/output based on the information present in section 3.3                               | Digital Ports |

Table 4 - Hardware Constraints



### 4.5 Communication/Network Constraints

None

## 4.6 Diagnostic Constraints

None

## 4.7 Dimensioning Constraints

| Constraint ID    | Descri                                                                                 | ption                         | Туре              |  |
|------------------|----------------------------------------------------------------------------------------|-------------------------------|-------------------|--|
|                  | {HLD-0014(0)}                                                                          | (Covers: SRS-0043)            | 0)}               |  |
| (Assignation: )  | {Test Method: Static Test}                                                             | {Integration Phase: }         | {Justification: } |  |
| [PERF_1]         | The CPU load shall not exceed 8                                                        | 30%.                          | CPU Load          |  |
|                  | {HLD-0015(0)} {Covers: SRS-0044                                                        |                               |                   |  |
| {Assignation: }  | {Test Method: Static Test}                                                             | {Integration Phase: }         | {Justification: } |  |
| [PERF_2]         | The code size in FLASH shall no                                                        | t exceed 1 KB.                | Code Size         |  |
|                  | {HLD-0016(0)}                                                                          | {Covers: SRS-0045(            | 0)}               |  |
| {Assignation: }  | {Test Method: Static Test}                                                             | {Integration Phase: }         | {Justification: } |  |
| [PERF_3]         | The RAM consumption shall not                                                          | exceed 1 KB.                  | Code Size         |  |
|                  | {HLD-0017(0)} {Covers: SRS-0046                                                        |                               |                   |  |
| {Assignation: }  | {Test Method: Static Test}                                                             | {Integration Phase: }         | {Justification: } |  |
| [PERF_4]         | The stack consumption shall not                                                        | exceed 1 KB.                  | Code Size         |  |
|                  | {HLD-0018(0)}                                                                          | {Covers: SRS-0041(            | 0)}               |  |
| (Assignation: )  | {Test Method: Static Test}                                                             | {Integration Phase: }         | {Justification: } |  |
| [PERF_5]         | The source code shall conform to                                                       | o MISRA rules.                | Code Quality      |  |
|                  | {HLD-0019(0)}                                                                          | {Covers: SRS-0042(            | 0)}               |  |
| {Assignation: }  | {Test Method: Static Test}                                                             | {Integration Phase: }         | {Justification: } |  |
| [PERF_6]         | [PERF_6] The source code shall follow the Valeo naming, coding and presentation rules. |                               |                   |  |
|                  | {HLD-0020(0)} {Covers: SRS-003                                                         |                               |                   |  |
| (Assignation: TI | F} {Test Method: Component Test}                                                       | {Integration Phase: }         | {Justification: } |  |
| [PERF_7]         | The response time for a transition shall not exceed 20 ms.                             | on between a state to another | Performance       |  |

Table 5 - Dimensioning Constraints



## 5 Real Time Analysis

#### 5.1 Processes Identification

| Constraint ID | Basic Operation                                                                           | Process | Period /<br>Frequency | Response<br>Time | Jitter |
|---------------|-------------------------------------------------------------------------------------------|---------|-----------------------|------------------|--------|
| [INP_1]       | Managing the correct capturing of the HAZZARD_PB press                                    | [HIF]   | 200ms                 | N/A              |        |
| [INP_2]       | Managing the correct capturing of both the STEP_DOWN_PB and STEP_UP_PB presses            | [TIF]   | 100ms                 | N/A              |        |
| [OUT_1]       | Control the turning on of the SSD of RIGHT and LEFT SSDs                                  | [TIF]   | 200ms                 | N/A              | ±5ms   |
| [OUT_2]       | Control the turning off of the SSD of RIGHT and LEFT SSDs                                 | [TIF]   | 300ms                 | N/A              | ±5ms   |
| [OUT_3]       | Control the turning on of the SSD of the HAZARD signal                                    | [HIF]   | 200ms                 | N/A              | ±5ms   |
| [OUT_4]       | Control the turning off of the SSD of the HAZARD signal                                   | [HIF]   | 400ms                 | N/A              | ±5ms   |
| [PREF_7]      | Control the response time to guarantee smooth transitions between different system states | [TIF]   |                       | 20ms             |        |

Table 6 - Processes Identification

## 5.2 Timing Bases Identification

| Process | Description                      | Constraints | Period /<br>Frequency | Response<br>Time | Jitter |
|---------|----------------------------------|-------------|-----------------------|------------------|--------|
| [HIF]   | HAZARD signal capturing          | [INP_1]     | 200ms                 |                  |        |
|         | Turn on of both Left/Right SSDs  | [OUT_3]     | 200ms                 |                  | ±5ms   |
|         | Turn off of both Left/Right SSDs | [OUT_4]     | 400ms                 |                  | ±5ms   |
| [TIF]   | STEP_DOWN/UP capturing           | [INP_2]     | 100ms                 |                  |        |
|         | Turn on of Left/Right SSDs       | [OUT_1]     | 200ms                 |                  | ±5ms   |
|         | Turn off of Left/Right SSDs      | [OUT_2]     | 300ms                 |                  | ±5ms   |
|         | Guarantee smooth transitions     | [PREF_7]    |                       | 20ms             |        |

Table 7 - Time Bases Identification



## **5.3 Software Operating Modes**

The following table lists the software operating modes.

| Operating Mode | Description                                                  | Constraints  |
|----------------|--------------------------------------------------------------|--------------|
| [IDLE]         | Both left and right SSDs must be switched off                |              |
| [LEFT_BLINK]   | Only the left SSD is to be blinking as specified above       | [OUT1, OUT2] |
| [RIGHT_BLINK]  | Only the right SSD is to be blinking as specified above      | [OUT1, OUT2] |
| [HAZARD_BLINK] | Both left and right SSDs must be blinking as specified above | [OUT3, OUT4] |

Table 8 - Software Operating Modes

The following diagram shows the software operating modes including transitions.



Figure 2 - Software Operating Modes and Transitions

The following table describes the transitions between the operating modes.

| Transition ID | Event Description                                                                                                     |
|---------------|-----------------------------------------------------------------------------------------------------------------------|
| [TRANS01]     | The system goes to RIGHT_BLINK state upon a correct press of STEP_UP_PB                                               |
| [TRANS02]     | The system goes to IDLE state upon a correct press of STEP_DOWN_PB                                                    |
| [TRANS03]     | The system goes to RIGHT_BLINK state upon a correct press of HAZZARD_PB given that the previous state was RIGHT_BLINK |
| [TRANS04]     | The system goes to the HAZARD_BLINK state upon a correct press of HAZARD_PB                                           |
| [TRANS05]     | The system goes to the HAZARD_BLINK state upon a correct press of HAZARD_PB                                           |
| [TRANS06]     | The system goes to LEFT_BLINK state upon a correct press of HAZZARD_PB given that the previous state was LEFT_BLINK   |

© Valeo Inter-branch Automotive Software

Page 14/48



#### **Induction Training Exercise - HLD Design**

Version 1.3

| Transition ID | Event Description                                                                                       |
|---------------|---------------------------------------------------------------------------------------------------------|
| [TRANS07]     | The system goes to LEFT_BLINK state upon a correct press of STEP_DOWN_PB                                |
| [TRANS08]     | The system goes to IDLE state upon a correct press of STEP_UP_PB                                        |
| [TRANS09]     | The system goes to the HAZARD_BLINK state upon a correct press of HAZARD_PB                             |
| [TRANS10]     | The system goes to IDLE state upon a correct press of HAZZARD_PB given that the previous state was IDLE |
| [POWERUP]     | Upon power up, the system directly goes to the IDLE state                                               |

Table 9 - Transitions Description

The following table lists the processes to be performed in each operating mode.

| Operating Mode | Processes |
|----------------|-----------|
| [IDLE]         | MODE      |
| [LEFT_BLINK]   | TIF       |
| [RIGHT_BLINK]  | TIF       |
| [HAZARD_BLINK] | HIF       |

#### 5.4 Shared Resources

#### 5.4.1 Hardware Resources

None

#### 5.4.2 Software Resources

## 6 Design Alternatives and Justification



## 7 Architectural Design

#### 7.1 Real Time Architecture

#### 7.1.1 Interrupts

| IT        | Period | Process   | Maximum<br>Delay | Response<br>Time | Estimated Duration | Estimated CPU Load | IT<br>Level |
|-----------|--------|-----------|------------------|------------------|--------------------|--------------------|-------------|
| [RESET]*  | -      | -         |                  |                  | 2us                | 0.00%              | 1           |
| [UNUSED]* | -      | -         |                  |                  | 2us                | 0.00%              | 1           |
| [RTC]     | 1ms    | [SCHED_P] |                  |                  | 8us                | 0.80%              | 1           |
|           |        |           |                  | Estimate         | d CPU Load         | 0.80%              |             |

<sup>\*</sup> Those interrupts are not used by the system and are not expected to occur; accordingly no estimated CPU load is taken into account

#### 7.1.2 Cyclic Tasks

| Task    | Period             | Process   | Maximum<br>Delay | Response<br>Time | Estimated Duration | Estimated CPU Load | Priorit<br>y |
|---------|--------------------|-----------|------------------|------------------|--------------------|--------------------|--------------|
| [TASK1] | 1ms                | [SCHED_P] |                  |                  | 20us               | 2.00%              | 1            |
| [TASK2] | 5ms                | [SSD_P]   |                  |                  | 182us              | 3.64%              | 1            |
| [TASK3] | 10ms               | [PBD_P]   |                  |                  | 10us               | 0.10%              | 1            |
| [TASK4] | 10ms               | [MODE_P]  |                  |                  | 160us              | 1.60%              | 1            |
| [TASK5] | 10ms               | [HIF_P]   |                  |                  | 64us               | 0.64%              | 1            |
| [TASK6] | 10ms               | [TIF_P]   |                  |                  | 82us               | 0.82%              | 1            |
|         | Estimated CPU Load |           |                  |                  |                    | 8.80%              |              |

#### 7.1.3 Event-triggered Tasks

None

#### 7.1.4 Estimated Workload

Total Workload Estimate = 9.60%.

#### 7.1.5 Shared Resources Protection

#### 7.1.5.1 Hardware Resources

None

#### 7.1.5.2 Software Resources



#### 7.1.6 Dynamic Architecture Requirements

#### 7.1.6.1 Operating System Configuration

The following table describes the required operating system configuration for the dynamic decisions taken of the interrupts and tasks in the system and allocates them to a certain component.

For more information about the interrupts and tasks design; refer to sections 7.1.1, 7.1.2 and 7.1.3.

| Description                                       |                                 | Intermed / Tools      |          | Туре                          |  |
|---------------------------------------------------|---------------------------------|-----------------------|----------|-------------------------------|--|
| Desc                                              | cription                        | Interrupt / Task      |          | Value                         |  |
| {HLD-0021(0)}                                     |                                 | {Covers: }            |          |                               |  |
| {Assignation: SCHED}                              | {Test Method: Integration Test} | {Integration Phase: } | {Just    | ification: Real Time Design } |  |
| RTC interrupt periodicity                         |                                 | [SCHED_P]             |          | Tick                          |  |
| Ter o interrupt periodicity                       |                                 | [001125_1]            |          | 1ms                           |  |
| {HLD-0022(0)}                                     |                                 | {Covers: }            |          |                               |  |
| {Assignation: SCHED}                              | {Test Method: Integration Test} | {Integration Phase: } | {Just    | ification: Real Time Design } |  |
| RTC interrupt priority                            | [SCHED_P]                       |                       | Priority |                               |  |
| Ter o interrupt priority                          | [001125_1]                      |                       | 1        |                               |  |
| {HLD-0023(0)}                                     |                                 | {Covers: }            |          |                               |  |
| {Assignation: SCHED}                              | {Test Method: Integration Test} | {Integration Phase: } | {Just    | ification: Real Time Design } |  |
| Management of the differ                          | ent system tasks                | [SCHED_P]             |          | Period                        |  |
| management of the differ                          | [001120_1]                      |                       | 1ms      |                               |  |
| {HLD-0024(0)}                                     |                                 | {Covers: }            |          |                               |  |
| {Assignation: SCHED}                              | {Test Method: Integration Test} | {Integration Phase: } | {Just    | ification: Real Time Design } |  |
| Management of the different system tasks priority |                                 | ICCHED DI             |          | Priority                      |  |
|                                                   |                                 | [SCHED_P]             |          | 1                             |  |
| {HLD-0025(0)}                                     |                                 | {Covers: }            |          |                               |  |
| {Assignation: SSD}                                | {Test Method: Integration Test} | {Integration Phase: } | {Just    | ification: Real Time Design } |  |
| Management of the 2 SS                            | Do.                             | [SSD_P]               |          | Period                        |  |
| Management of the 3 SS                            | DS                              |                       |          | 5ms                           |  |
| {HLD-0026(0)}                                     |                                 | {Covers: }            |          |                               |  |
| {Assignation: SCHED}                              | {Test Method: Integration Test} | {Integration Phase: } | {Just    | ification: Real Time Design } |  |
| Management of the 2 CC                            | Do priority                     | ICCD DI               |          | Priority                      |  |
| Management of the 3 SS                            | DS priority                     | [SSD_P]               |          | 1                             |  |
| {HLD-0027(0)}                                     |                                 | {Covers: }            |          |                               |  |
| {Assignation: PBD}                                | {Test Method: Integration Test} | {Integration Phase: } | {Just    | ification: Real Time Design } |  |
| Management of the puch                            | huttone                         | [PBD P]               |          | Period                        |  |
| Management of the push                            | Duttons                         | [PDD_P]               |          | 10ms                          |  |
| {HLD-0028(0)}                                     |                                 | {Covers: }            |          |                               |  |
| {Assignation: SCHED}                              | {Test Method: Integration Test} | {Integration Phase: } | {Just    | ification: Real Time Design } |  |
| Management of the push                            | huttone priority                | IDDU DI               |          | Priority                      |  |
| Management of the push buttons priority           |                                 | [PBD_P]               |          | 1                             |  |
| {HLD-0029(0)}                                     |                                 | {Covers: }            |          |                               |  |
| {Assignation: MODE}                               | {Test Method: Integration Test} | {Integration Phase: } | {Just    | ification: Real Time Design } |  |
| Management of different                           | evetem operating modes          | [MODE D]              |          | Period                        |  |
| Management of different system operating modes    |                                 | [MODE_P]              |          | 10ms                          |  |
|                                                   |                                 |                       |          |                               |  |



#### **Induction Training Exercise - HLD Design**

Version 1.3

| Dana                                         |                                 | lista musik / Table   | Туре                               |
|----------------------------------------------|---------------------------------|-----------------------|------------------------------------|
| Desc                                         | ription                         | Interrupt / Task      | Value                              |
| {HLD-0030(0)}                                |                                 | {Covers: }            | ·                                  |
| {Assignation: SCHED}                         | {Test Method: Integration Test} | {Integration Phase: } | {Justification: Real Time Design } |
| Management of different                      | system operating modes          | [MODE D]              | Priority                           |
| priority                                     |                                 | [MODE_P]              | 1                                  |
| {HLD-0031(0)}                                |                                 | {Covers: }            |                                    |
| {Assignation: HIF}                           | {Test Method: Integration Test} | {Integration Phase: } | {Justification: Real Time Design } |
| Management of the base                       | ada interfere                   | נוווב די              | Period                             |
| Management of the hazards interface          |                                 | [HIF_P]               | 10ms                               |
| {HLD-0032(0)}                                |                                 | {Covers: }            | ·                                  |
| {Assignation: SCHED}                         | {Test Method: Integration Test} | {Integration Phase: } | {Justification: Real Time Design } |
| Manager                                      | a ta tara da a a a da de        | THE DI                | Priority                           |
| Management of the hazar                      | as interrace priority           | [HIF_P]               | 1                                  |
| {HLD-0033(0)}                                |                                 | {Covers: }            |                                    |
| {Assignation: TIF}                           | {Test Method: Integration Test} | {Integration Phase: } | {Justification: Real Time Design } |
| Manager of a fide of a con-                  | . Cata da                       | THE DI                | Period                             |
| Management of the turning interface          |                                 | [TIF_P]               | 10ms                               |
| {HLD-0034(0)}                                |                                 | {Covers: }            |                                    |
| {Assignation: SCHED}                         | {Test Method: Integration Test} | {Integration Phase: } | {Justification: Real Time Design } |
| Management of the translation                | a interfere priority            | ודור סי               | Priority                           |
| Management of the turning interface priority |                                 | [TIF_P]               | 1                                  |

#### 7.1.6.2 Estimated Execution Times

The following table lists all estimated execution times for the interrupts/tasks in addition to distributing the operations done of each task on different components.

For more information about the interrupts and tasks design; refer to sections 7.1.1, 7.1.2 and 7.1.3.

| De                       | escription         |               | Interrupt / Tas       | sk      | Duration                     |
|--------------------------|--------------------|---------------|-----------------------|---------|------------------------------|
| {HLD-0035(0              | )}                 |               | {Covers: }            |         |                              |
| {Assignation: }          | {Test Method: Inte | gration Test} | {Integration Phase: } | {Justif | fication: Real Time Design } |
| Execution time for the F | RTC interrupt      |               | [RTC]                 |         | 8us                          |
| {HLD-0036(0              | )}                 |               | {Covers: }            |         |                              |
| {Assignation: }          | {Test Method: Inte | gration Test} | {Integration Phase: } | {Justif | fication: Real Time Design } |
| Execution time for TAS   | K1                 |               | [TASK1]               |         | 20us                         |
| {HLD-0037(0              | )}                 |               | {Covers: }            |         |                              |
| {Assignation: }          | {Test Method: Inte | gration Test} | {Integration Phase: } | {Justif | fication: Real Time Design } |
| Execution time for TAS   | K2                 |               | [TASK2]               |         | 182us                        |
| {HLD-0038(0              | )}                 |               | {Covers: }            |         |                              |
| {Assignation: }          | {Test Method: Inte | gration Test} | {Integration Phase: } | {Justif | fication: Real Time Design } |
| Execution time for TAS   | K3                 |               | [TASK3]               |         | 10us                         |
| {HLD-0039(0              | )}                 |               | {Covers: }            |         |                              |
| {Assignation: }          | {Test Method: Inte | gration Test} | {Integration Phase: } | {Justif | fication: Real Time Design } |



| Desc                     | ription                         | Interrupt / Task      |         | Duration                    |
|--------------------------|---------------------------------|-----------------------|---------|-----------------------------|
| Execution time for TASK4 |                                 | [TASK4]               |         | 160us                       |
| {HLD-0040(0)}            |                                 | {Covers: }            |         |                             |
| {Assignation: }          | {Test Method: Integration Test} | {Integration Phase: } | {Justif | ication: Real Time Design } |
| Execution time for TASK5 |                                 | [TASK5]               |         | 64us                        |
| {HLD-0041(0)}            |                                 | {Covers: }            |         |                             |
| {Assignation: }          | {Test Method: Integration Test} | {Integration Phase: } | {Justif | ication: Real Time Design } |
| Execution time for TASK6 |                                 | [TASK6]               |         | 82us                        |

### 7.2 Static Architecture (Internal Interfaces)

#### 7.2.1 Layered Architecture



Figure 3 - Layered System Architecture

#### 7.2.2 Components Design

Port Driver (PORT): Configures the different microcontroller ports.

Mcu Driver (MCU): Configures the microcontroller clock.

Digital Inputs/Outputs Driver (DIO): Commands the digital outputs and reads the digital inputs.

Seven Segment Driver (SSD): Hardware abstraction driver to command the seven segments.

Push Button Driver (PBD): Hardware abstraction driver to read the push buttons.

Mode Manager (MODE): Manages the different modes of the system.

Hazards Interface (HIF): Manages everything related to the hazard TCM operation.

<u>Turning Interface (TIF):</u> Manages everything related to the right and left TCM operations.

Scheduler: Responsible for scheduling different system tasks and manages the RTC interrupt.



#### 7.2.3 Interfaces Design



Figure 4 - Interfaces Design

#### 7.2.4 Subsystems

For the sake of the exercise, the MCAL layer will be in one subsystem, HAL layer will be in one subsystem and the APP layer will be one subsystem. For the "Scheduler" component, it will be considered part of the APP layer.

### 7.3 Memory Consumption

#### 7.3.1 Memory Size

Refer to constraints in section 4.7 for details about memory size requirements.

#### 7.3.2 Memory Map

The default memory mapping of the microcontroller shall be used. No specific memory mapping is required for this system.



## 8 Software Components

#### 8.1 MCAL Subsystem

#### 8.1.1 DIO Component

The DIO (Digital Input Output) component is responsible for reading and writing digital signals to the microcontroller channels.

#### 8.1.1.1 Resources Constraints

None

#### 8.1.1.2 External Interfaces (Dependencies)

{HLD-0059(0)} {Covers: }
{Assignation: DIO} {Test Method: Static Test} {Integration Phase: } {Justification: }

#### The DIO component shall include the microcontroller header file through "mc9s08jm32.h".

{HLD-0060(0)} {Covers: }
{Assignation: DIO} {Test Method: Static Test} {Integration Phase: } {Justification: }

The DIO component shall include the basic types through the inclusion of "BTY\_int.h".

#### 8.1.1.3 Design Constraints

None

#### 8.1.1.4 Component APIs

#### 8.1.1.4.1 Symbols

None

#### 8.1.1.4.2 Types

|                       | Туре                        |                          | Status                 |  |
|-----------------------|-----------------------------|--------------------------|------------------------|--|
| {HLD-006              | 65(0)}                      |                          | {Covers: }             |  |
| {Assignation: DIO}    | {Test Method: Integration T | est} {Integration Phase: | e: } {Justification: } |  |
| Channel Groups Struct | ure                         |                          | New                    |  |

#### 8.1.1.4.3 Constants

None

#### 8.1.1.4.4 Data



#### 8.1.1.4.5 **Services**

8.1.1.4.5.1 DIO\_vidWriteChannelGroup

|                    |         | Charmelord      | *F                                             | 10                          |                   |
|--------------------|---------|-----------------|------------------------------------------------|-----------------------------|-------------------|
| {HLD-00            | 061(0)} |                 |                                                | {Covers: }                  |                   |
| {Assignation: DIO} |         | {Test Method: I | ntegration Test}                               | {Integration Phase: }       | {Justification: } |
| Syntax:            | void    | DIO_vidWi       | riteChanne                                     | lGroup(                     |                   |
| ,                  |         |                 | DIO_                                           | tenuChannelGroupId e        | nuChannelGroupId, |
|                    |         |                 | uint                                           | 8 u8Value)                  |                   |
| Description:       | Write   | s the value to  | a group of m                                   | nicrocontroller channels    |                   |
| Sync/Async:        | Synch   | nronous         |                                                |                             |                   |
| Reentrancy:        | non re  | eentrant        |                                                |                             |                   |
| Parameters (in):   | enuC    | hannelGroup     | Id Group I                                     | D to be written to (Group 1 | / Group 2)        |
|                    | u8Val   | ue              | Value to                                       | be written to the whole gro | oup               |
| Parameters (out):  | None    |                 | None                                           |                             |                   |
| Return value:      | None    |                 | None                                           |                             |                   |
| Caveats:           | None    |                 | <u>.                                      </u> |                             |                   |
| Configuration:     | None    |                 |                                                |                             |                   |
| MemSegment:        | Defau   | ılt compiler m  | nemories will                                  | be used                     |                   |
| MemClass:          | Defau   | ılt compiler m  | nemories will l                                | be used                     |                   |

#### 8.1.1.4.5.2 DIO\_vidWriteChannel

| {HLD-00            | 062(0)} |                 |                  | {Covers: }                                        |                   |
|--------------------|---------|-----------------|------------------|---------------------------------------------------|-------------------|
| {Assignation: DIO} |         | {Test Method: I | ntegration Test} | {Integration Phase: }                             | {Justification: } |
| Syntax:            | void    | DIO_vidW        | riteChanne       | l(     DIO_tenuChannelId     DIO_tenuChannelLev ) | •                 |
| Description:       | Writes  | the value to    | a single mic     | rocontroller channel                              |                   |
| Sync/Async:        | Synch   | ronous          |                  |                                                   |                   |
| Reentrancy:        | non re  | entrant         |                  |                                                   |                   |
| Parameters (in):   | enuCl   | nannelld        | ID of the        | e microcontroller channel to                      | o write to        |
|                    | enuLe   | evel            | Channe           | el level (HIGH/LOW)                               |                   |
| Parameters (out):  | None    |                 | None             |                                                   |                   |
| Return value:      | None    |                 | None             |                                                   |                   |
| Caveats:           | None    |                 |                  |                                                   |                   |
| Configuration:     | None    | ·               | ·                |                                                   |                   |
| MemSegment:        | Defau   | It compiler m   | nemories will    | be used                                           |                   |
| MemClass:          | Defau   | It compiler m   | nemories will    | be used                                           |                   |

#### 8.1.1.4.5.3 DIO\_u8ReadChannel

| 0.1.1.4.0.0 | DIO_acricaa   | Onamici       |                   |                       |                   |
|-------------|---------------|---------------|-------------------|-----------------------|-------------------|
|             | {HLD-0063(0)} |               |                   | {Covers: }            |                   |
| {Assign     | nation: DIO}  | {Test Method: | Integration Test} | {Integration Phase: } | {Justification: } |



#### **Induction Training Exercise - HLD Design**

Version 1.3

| Syntax:           | uint8 DIO_u8ReadC      | hannel(DIO_tenuChannelId enuChannelId)         |
|-------------------|------------------------|------------------------------------------------|
| Description:      | Reads the value from a | a microcontroller channel                      |
| Sync/Async:       | Synchronous            |                                                |
| Reentrancy:       | non reentrant          |                                                |
| Parameters (in):  | enuChannelld           | ID of the microcontroller channel to read from |
| Parameters (out): | None                   | None                                           |
| Return value:     | uint8                  | Acquired value read from the channel           |
| Caveats:          | None                   |                                                |
| Configuration:    | None                   |                                                |
| MemSegment:       | Default compiler memo  | ories will be used                             |
| MemClass:         | Default compiler memo  | ories will be used                             |

8.1.1.4.6 Tasks

None

8.1.1.4.7 Call-backs

None

8.1.1.4.8 Interrupts

None

#### 8.1.1.5 Component Configuration

| Configuration Pa        | rameter          |                  | Range                  | Value                 |
|-------------------------|------------------|------------------|------------------------|-----------------------|
|                         |                  | Descr            | iption                 |                       |
| {HLD-(                  | 0064(0)}         |                  |                        | {Covers: }            |
| {Assignation: DIO}      | {Test Method: Ir | ntegration Test} | {Integration Phase:    | } {Justification: }   |
| Channel Gro             | ups              | Left t           | o the design           | N/A                   |
| Defines different chann | el groups from   | different micr   | ocontroller ports into | o a single structure. |

#### 8.1.2 MCU Component

The MCU component is responsible for the initialization process of the micro-controller that is related to adjusting the clock frequency, defining the interrupt vector table ... etc. It only communicates with the scheduler interface to call it when an interrupt occur through "SCHED\_vidRtcInterrupt".

#### 8.1.2.1 Resources Constraints

#### 8.1.2.2 External Interfaces (Dependencies)

The MCU component shall use the service "SCHED\_vidRtcInterrupt" from the SCHED component through the inclusion of "SCHED\_int.h".

{HLD-0067(0)} {Covers: }
{Assignation: MCU} {Test Method: Static Test} {Integration Phase: } {Justification: }

The MCU component shall include the basic types through the inclusion of "BTY\_int.h".

 $\begin{tabular}{ll} $\{$HLD-0068(0)\}$ & \{Covers: \} \\ \{Assignation: MCU\} & \{Test Method: Static Test\} & \{Integration Phase: \} & \{Justification: \} \\ \end{tabular}$ 

The MCU component shall include the compiler types through the inclusion of "CTY\_int.h".

{HLD-0069(0)} {Covers: }

{Assignation: MCU} {Test Method: Static Test} {Integration Phase: } {Justification: }

The MCU component shall include the microcontroller header file through "mc9s08jm32.h".

#### 8.1.2.3 Design Constraints

None

#### 8.1.2.4 Component APIs

8.1.2.4.1 Symbols

None

8.1.2.4.2 Types

None

#### 8.1.2.4.3 Constants

| Constant Name                      |                      | Туре         | •               |               | Value             |
|------------------------------------|----------------------|--------------|-----------------|---------------|-------------------|
|                                    |                      | Descrip      | tion            |               |                   |
| {HLD-0070(0)                       | }                    |              |                 | {Covers       | s: }              |
| {Assignation: MCU}                 | {Test Method: Integr | ration Test} | {Integration    | Phase: }      | {Justification: } |
| MCU_u16INT_VTAB_ADDRE              | ESS arra             | y of void *  | function        |               | N/A               |
| Defines the list of different into | errupt function      | s to be ca   | lled in case of | f an interrup | t occurred        |

#### 8.1.2.4.4 Data

None

#### 8.1.2.4.5 Services

#### 8.1.2.4.5.1 MCU vidInit

| {HLD-00            | )71(0)} |               |                  | {Covers: }            |                   |
|--------------------|---------|---------------|------------------|-----------------------|-------------------|
| {Assignation: MCU} |         | {Test Method: | ntegration Test} | {Integration Phase: } | {Justification: } |
| Syntax:            | void    | MCU_vidI      | nit(void)        |                       |                   |



#### **Induction Training Exercise - HLD Design**

Version 1.3

| Description:      | Initializes the microcon | troller clock and prepares the RTC |
|-------------------|--------------------------|------------------------------------|
| Sync/Async:       | Synchronous              |                                    |
| Reentrancy:       | non reentrant            |                                    |
| Parameters (in):  | None                     | None                               |
| Parameters (out): | None                     | None                               |
| Return value:     | None                     | None                               |
| Caveats:          | None                     |                                    |
| Configuration:    | None                     |                                    |
| MemSegment:       | Default compiler memo    | ries will be used                  |
| MemClass:         | Default compiler memo    | ries will be used                  |

{HLD-0072(0)} {Covers: SRS-0040(0)} {Assignation: MCU} {Test Method: Component Test} {Integration Phase: } {Justification: }

This service shall initialize the PLL to give a frequency of 24MHz.

{HLD-0073(0)} {Covers: }

{Assignation: MCU} {Test Method: Component Test} {Integration Phase: } {Justification: Refer to sec 7.1}

This service shall set the Real Time Counter to fire every 1ms.

8.1.2.4.6 Tasks

None

8.1.2.4.7 Call-backs

None

8.1.2.4.8 Interrupts

None

#### 8.1.2.5 Component Configuration

None

#### 8.1.3 PORT Component

The PORT component is responsible for configuring the microcontroller ports to their different functionalities as per specified in the microcontroller's datasheet and required in the system. It shall be responsible for configuring all the external interfaces defined in section 3.3.

#### 8.1.3.1 Resources Constraints

#### 8.1.3.2 External Interfaces (Dependencies)

 $\label{eq:covers:} $$ \{Assignation: PORT\} $$ \{Test Method: Static Test\} $$ \{Integration Phase: \} $$ \{Justification: \}$$ 

The PORT component shall include the microcontroller header file through "mc9s08jm32.h".

FOR Ecomponent shall include the microcontroller header life through imcessojmsz.r

 $\{ \text{HLD-0075(0)} \} \\ \{ \text{Assignation: PORT} \} \\ \{ \text{Test Method: Static Test} \} \\ \{ \text{Integration Phase: } \} \\ \{ \text{Justification: } \}$ 

The PORT component shall include the basic types through the inclusion of "BTY\_int.h".

#### 8.1.3.3 Design Constraints

None

#### 8.1.3.4 Component APIs

8.1.3.4.1 Symbols

None

8.1.3.4.2 Types

| Type Name              | Туре                            |                          | Members           |
|------------------------|---------------------------------|--------------------------|-------------------|
|                        | Descri                          | ption                    |                   |
| {HLD-0                 | 076(0)}                         | {Co                      | vers: }           |
| {Assignation: PORT}    | {Test Method: Integration Test} | {Integration Phase: }    | {Justification: } |
| 01 115                 |                                 |                          | 0 56              |
| Channel IDs            | enumerati                       |                          | 056               |
|                        | ne different channels availab   | e in the microcontroller |                   |
| umeration to define th | ne different channels availab   | e in the microcontroller | ·                 |

#### 8.1.3.4.3 Constants

None

8.1.3.4.4 Data

None

#### 8.1.3.4.5 Services

#### 8.1.3.4.5.1 **PORT\_vidInit**

| ornornorn corti     |         |                                                                        |                   |                       |                   |  |
|---------------------|---------|------------------------------------------------------------------------|-------------------|-----------------------|-------------------|--|
| {HLD-0078(0)}       |         |                                                                        | {Covers: }        |                       |                   |  |
| (Assignation: PORT) |         | {Test Method: I                                                        | Integration Test} | {Integration Phase: } | {Justification: } |  |
| Syntax:             | void    | <pre>void PORT_vidInit(void)</pre>                                     |                   |                       |                   |  |
| Description:        | Initial | nitializes the different microcontroller ports to their correct values |                   |                       |                   |  |
| Sync/Async:         | Syncl   | Synchronous                                                            |                   |                       |                   |  |

| Reentrancy:       | non reentrant                          |                    |  |  |
|-------------------|----------------------------------------|--------------------|--|--|
| Parameters (in):  | None                                   | None               |  |  |
| Parameters (out): | None None                              |                    |  |  |
| Return value:     | None None                              |                    |  |  |
| Caveats:          | None                                   |                    |  |  |
| Configuration:    | None                                   | None               |  |  |
| MemSegment:       | Default compiler memories will be used |                    |  |  |
| MemClass:         | Default compiler memo                  | ories will be used |  |  |

 $\{ HLD-0079(0) \} \\ \{ Assignation: PORT \} \\ \{ Test Method: Component Test \} \\ \{ Integration Phase: \} \\ \{ Justification: \} \\ \{ Justific$ 

This service shall be responsible for initializing all microcontroller ports as Digital Input Output ports and setting their values as specified in section 3.3.

8.1.3.4.6 Tasks

None

8.1.3.4.7 Call-backs

None

8.1.3.4.8 Interrupts

None

#### 8.1.3.5 Component Configuration

| Configuration Par      | ameter           |                 | Range                 | Value                       |
|------------------------|------------------|-----------------|-----------------------|-----------------------------|
|                        |                  | Descr           | iption                |                             |
| {HLD-008               | 30(0)}           |                 |                       | {Covers: }                  |
| {Assignation: PORT}    | {Test Method: Ir | tegration Test} | {Integration Phase: } | {Justification: }           |
| Ports Direction        | าร               | 07 (max         | imum # of ports)      | N/A                         |
| infiguration parameter | that defines     | the direction   | ns of each port of    | the microcontroller. The ty |

Configuration parameter that defines the directions of each port of the microcontroller. The type "BTY\_tuniPort" shall be used to facilitate the definition of ports directions.

## 8.2 HAL Subsystem

#### 8.2.1 SSD Component

The SSD component (Seven Segment Driver) is responsible for driving the seven segment displays available in this system with the required value of "8" when ON and assure that when OFF all connected pins to the seven segments are derived OFF. It communicates with the DIO component in the MCAL layer as it uses the service "DIO\_vidWriteChannel" from it.



#### 8.2.1.1 Resources Constraints

None

#### 8.2.1.2 External Interfaces (Dependencies)

The SSD component shall use the service "DIO\_vidWriteChannel" from the DIO component through the inclusion of "DIO\_int.h".

{HLD-0082(0)} {Covers: }
{Assignation: SSD} {Test Method: Static Test} {Integration Phase: } {Justification: }

The SSD component shall include the basic types through the inclusion of "BTY\_int.h".

#### 8.2.1.3 Design Constraints

None

#### 8.2.1.4 Component APIs

8.2.1.4.1 Symbols

None

8.2.1.4.2 Types

None

8.2.1.4.3 Constants

None

8.2.1.4.4 Data

None

#### 8.2.1.4.5 Services

#### 8.2.1.4.5.1 SSD\_vidInit

| {HLD-0083(0)}                      |         |              | {Covers: }       |                       |                   |  |
|------------------------------------|---------|--------------|------------------|-----------------------|-------------------|--|
| {Assignation: SSD} {Test Method: I |         |              | ntegration Test} | {Integration Phase: } | {Justification: } |  |
| Syntax:                            | void    | SSD_vidIr    | nit(void)        |                       |                   |  |
| Description:                       | Initial | izes the SSD | component        |                       |                   |  |
| Sync/Async:                        | Sync    | Synchronous  |                  |                       |                   |  |
| Reentrancy:                        | non r   | eentrant     |                  |                       |                   |  |
| Parameters (in):                   | None    | None None    |                  |                       |                   |  |
| Parameters (out):                  | None    | None None    |                  |                       |                   |  |
| Return value:                      | None    |              | None             |                       |                   |  |



| Caveats:       | None                                   |
|----------------|----------------------------------------|
| Configuration: | None                                   |
| MemSegment:    | Default compiler memories will be used |
| MemClass:      | Default compiler memories will be used |

8.2.1.4.5.2 SSD SetDisplayedNumber

| 8.2.1.4.5.2 SSD_SetDisplayedNumber |                                                              |                                        |                  |                            |                   |  |  |
|------------------------------------|--------------------------------------------------------------|----------------------------------------|------------------|----------------------------|-------------------|--|--|
| {HLD-00                            | 084(0)}                                                      |                                        |                  | {Covers: }                 |                   |  |  |
| {Assignation: SSD}                 |                                                              | {Test Method: I                        | ntegration Test} | {Integration Phase: }      | {Justification: } |  |  |
| Syntax:                            | void                                                         | void SSD_SetDisplayedNumber(           |                  |                            |                   |  |  |
|                                    | SSD_                                                         | tenuSegmer                             | ntId enuSe       | gmentId, uint8 u8Numb      | oer)              |  |  |
| Description:                       | Sets                                                         | the displayed                          | number valu      | e on the seven segment dis | plays             |  |  |
| Sync/Async:                        | Syncl                                                        | hronous                                |                  |                            |                   |  |  |
| Reentrancy:                        | non r                                                        | non reentrant                          |                  |                            |                   |  |  |
| Parameters (in):                   | enuSegmentId Segment to display the value on (right or left) |                                        |                  |                            | ght or left)      |  |  |
|                                    | u8Number Number to be displayed on the segment               |                                        |                  |                            |                   |  |  |
| Parameters (out):                  | None                                                         | None None                              |                  |                            |                   |  |  |
| Return value:                      | None                                                         |                                        | None             |                            |                   |  |  |
| Caveats:                           | None                                                         | None                                   |                  |                            |                   |  |  |
| Configuration:                     | None                                                         |                                        |                  |                            |                   |  |  |
| MemSegment:                        | Defa                                                         | Default compiler memories will be used |                  |                            |                   |  |  |
| MemClass:                          | Defa                                                         | ult compiler m                         | nemories will l  | be used                    |                   |  |  |

| {                  | HLD-0085(0)}                  |                       | {Covers: }        |
|--------------------|-------------------------------|-----------------------|-------------------|
| {Assignation: SSD} | {Test Method: Component Test} | {Integration Phase: } | {Justification: } |

This service sets a shared local variable with the value to be displayed on the seven segment present on board that is identified by the segment ID parameter.

#### 8.2.1.4.6 Tasks

#### 8.2.1.4.6.1 SSD\_vidTask

| (HLD-00            | {HLD-0086(0)}                    |               |                        | {Covers: }            |                   |  |  |
|--------------------|----------------------------------|---------------|------------------------|-----------------------|-------------------|--|--|
| {Assignation: SSD} | {Assignation: SSD} {Test Method: |               |                        | {Integration Phase: } | {Justification: } |  |  |
| Syntax:            | void                             | SSD_vidTa     | ask(void)              |                       |                   |  |  |
| Description:       | Task                             | of the SSD c  | <mark>ompone</mark> nt |                       |                   |  |  |
| Sync/Async:        | Sync                             | Synchronous   |                        |                       |                   |  |  |
| Reentrancy:        | non r                            | non reentrant |                        |                       |                   |  |  |
| Parameters (in):   | None                             | None None     |                        |                       |                   |  |  |
| Parameters (out):  | None                             | None None     |                        |                       |                   |  |  |
| Return value:      | None None                        |               |                        |                       |                   |  |  |
| Caveats:           | None                             | None          |                        |                       |                   |  |  |



{Justification: }

| Configuration: | None                                   |
|----------------|----------------------------------------|
| MemSegment:    | Default compiler memories will be used |
| MemClass:      | Default compiler memories will be used |

{HLD-0087(0)} {Covers: SRS-0016(0)} {Assignation: SSD} {Test Method: Component Test} {Integration Phase: } In case of the SSD is controlling the RIGHT SSD, SS\_SEG1 signal shall be issued with value HIGH. {HLD-0088(0)} {Covers: SRS-0016(0)} {Integration Phase: } {Assignation: SSD} {Test Method: Component Test} {Justification: } In case of the SSD is controlling the LEFT SSD, SS\_SEG2 signal shall be issued with value HIGH. {HLD-0089(0)} {Covers: SRS-0017(0)} {Assignation: SSD} {Test Method: Component Test} {Integration Phase: } In case of the SSD is controlling the RIGHT SSD, SS SEG2 signal shall be issued with value LOW. {Covers: SRS-0017(0)} {HLD-0090(0)} {Assignation: SSD} {Test Method: Component Test} {Integration Phase: } In case of the SSD is controlling the LEFT SSD, SS\_SEG1 signal shall be issued with value LOW. {HLD-0091(0)} {Covers: SRS-0014(0)} {Assignation: SSD} {Test Method: Component Test}

This task will issue a HIGH value on the corresponding SSD desired pins (as defined in the SRS) through the call to the service DIO\_vidWriteChannelGroup to display the required value that is stored in the shared local variable previously set in SSD SetDisplayedNumber.

{Integration Phase: }

{HLD-0092(0)} {Covers: SRS-0015(0)} {Assignation: SSD} {Test Method: Component Test} {Integration Phase: }

This task will issue a LOW value on the corresponding SSD desired pins (as defined in the SRS) through the call to the service DIO\_vidWriteChannelGroup to display the required value that is stored in the shared local variable previously set in SSD\_SetDisplayedNumber.

{HLD-0106(0)} {Covers: SRS-0014(0)} {Test Method: Component Test} {Assignation: SSD} {Integration Phase: } {Justification: }

To switch-on a certain segment of the Seven Segment Displays (a, b, c, d, e, f, g, or dp), the corresponding digital signal (SS\_A, SS\_B, SS\_C, SS\_D, SS\_E, SS\_F, SS\_G, or SS\_DOT respectively) -connected to the segment's pin of the SDD chips- must be issued with the value HIGH.

{HLD-0107(0)} {Covers: SRS-0015(0)} {Assignation: SSD} {Integration Phase: } {Justification: } {Test Method: Component Test}

To switch-off a certain segment of the Seven Segment Displays (a, b, c, d, e, f, g, or dp), the corresponding digital signal (SS\_A, SS\_B, SS\_C, SS\_D, SS\_E, SS\_F, SS\_G, or SS\_DOT respectively) -connected to the segment's pin of the SDD chips- must be issued with the value LOW.

{HLD-0108(0)} {Covers: SRS-0016(0)} {Assignation: SSD} {Test Method: Component Test} {Integration Phase: } {Justification: }

To enable the operation of LEFT SIGNAL SSD or RIGHT SIGNAL SSD, the corresponding digital signals (SS SEG2 or SS SEG1 respectively) shall be issued with the value HIGH.

{HLD-0109(0)} {Covers: SRS-0017(0)} {Assignation: SSD} {Test Method: Component Test} {Integration Phase: } {Justification: }

To disable the operation of LEFT\_SIGNAL\_SSD or RIGHT\_SIGNAL\_SSD, the corresponding digital signals (SS\_SEG2 or SS\_SEG1 respectively) shall be issued with the value LOW.

8.2.1.4.7 Call-backs

None

8.2.1.4.8 Interrupts

None

Page 31/48

#### 8.2.1.5 Component Configuration

None

#### 8.2.2 PBD Component

The PBD component (Push Buttons Driver) is responsible for detecting a correct press on the push buttons connected on the microcontroller pins. It communicates with the DIO component in the MCAL layer as it uses the service "DIO\_u8ReadChannel" from it.

#### 8.2.2.1 Resources Constraints

None

#### 8.2.2.2 External Interfaces (Dependencies)

{HLD-0093(0)} {Covers: }
{Assignation: PBD} {Test Method: Static Test} {Integration Phase: } {Justification: }

The PBD component shall use the service "DIO\_u8ReadChannel" from the DIO component through the inclusion of "DIO\_int.h".

{HLD-0094(0)} {Covers: } {Assignation: PBD} {Test Method: Static Test} {Integration Phase: } {Justification: }

The PBD component shall include the basic types through the inclusion of "BTY\_int.h".

#### 8.2.2.3 Design Constraints

None

#### 8.2.2.4 Component APIs

#### 8.2.2.4.1 Symbols

None

#### 8.2.2.4.2 Types

| Type Name                                          |         | Туре                      |                                         | Members                                      |                            |
|----------------------------------------------------|---------|---------------------------|-----------------------------------------|----------------------------------------------|----------------------------|
| Description                                        |         |                           |                                         |                                              |                            |
| {HLD-00                                            | 098(0)} |                           |                                         | {Covers                                      | s: }                       |
| {Assignation: PBD} {Test Method: Integration Test} |         | Method: Integration Test} | {Integration Phase: } {Justification: } |                                              | {Justification: }          |
| Push Button State                                  |         | enumeration               |                                         | PRE_PUSH<br>PRE_HOLD<br>PRE_RELE<br>UNDEFINE | O, HOLD,<br>ASE, RELEASED, |

#### 8.2.2.4.3 Constants

8.2.2.4.4 Data

None

#### 8.2.2.4.5 Services

#### 8.2.2.4.5.1 PBD vidInit

| 0.2.2.4.3.1   DD_V | Milit   |                                        | -                |                       |                   |  |
|--------------------|---------|----------------------------------------|------------------|-----------------------|-------------------|--|
| {HLD-00            | 095(0)} |                                        | {Covers: }       |                       |                   |  |
| (Assignation: PBD) |         | {Test Method: I                        | ntegration Test} | {Integration Phase: } | {Justification: } |  |
| Syntax:            | void    | void PBD_vidInit(void)                 |                  |                       |                   |  |
| Description:       | Initial | izes the PBD                           | component        |                       |                   |  |
| Sync/Async:        | Syncl   | nronous                                |                  |                       |                   |  |
| Reentrancy:        | non r   | non reentrant                          |                  |                       |                   |  |
| Parameters (in):   | None    |                                        | None             |                       |                   |  |
| Parameters (out):  | None    |                                        | None             |                       |                   |  |
| Return value:      | None    | None None                              |                  |                       |                   |  |
| Caveats:           | None    | None                                   |                  |                       |                   |  |
| Configuration:     | None    | None                                   |                  |                       |                   |  |
| MemSegment:        | Defa    | Default compiler memories will be used |                  |                       |                   |  |
| MemClass:          | Defa    | ılt compiler m                         | nemories will I  | pe used               |                   |  |

#### 8.2.2.4.5.2 PBD\_enuGetButtonState

| {HLD-00            | )99(0)}                                                             |                               | {Covers: }       |                           |                   |  |
|--------------------|---------------------------------------------------------------------|-------------------------------|------------------|---------------------------|-------------------|--|
| {Assignation: PBD} |                                                                     | {Test Method: I               | ntegration Test} | {Integration Phase: }     | {Justification: } |  |
| Syntax:            | PBD_tenuButtonState PBD_enuGetButtonState(                          |                               |                  |                           |                   |  |
|                    |                                                                     | PBD_tenuButtonId enuButtonId) |                  |                           |                   |  |
| Description:       | Sets                                                                | the displayed                 | number val       | ue on the seven segment d | isplays           |  |
| Sync/Async:        | Sync                                                                | Synchronous                   |                  |                           |                   |  |
| Reentrancy:        | non reentrant                                                       |                               |                  |                           |                   |  |
| Parameters (in):   | enuButtonId Button to check its status (down, up, hazard)           |                               |                  |                           | ıp, hazard)       |  |
| Parameters (out):  | PBD_tenuButtonState State of button as described in the types above |                               |                  |                           | e types above     |  |
| Return value:      | None                                                                |                               | None             |                           |                   |  |
| Caveats:           | None                                                                |                               |                  |                           |                   |  |
| Configuration:     | None                                                                |                               |                  |                           |                   |  |
| MemSegment:        | Default compiler memories will be used                              |                               |                  |                           |                   |  |
| MemClass:          | Defa                                                                | ult compiler m                | nemories will    | be used                   |                   |  |

{HLD-0100(0)} {Covers: }
{Assignation: PBD} {Test Method: Component Test} {Integration Phase: } {Justification: }

This service reads the state of the push button and returns it back to the caller. If the button ID passed is undefined, this service shall return UNDEFINED state.



#### 8.2.2.4.6 Tasks

#### 8.2.2.4.6.1 PBD vidTask

| 8.2.2.4.0.1 PDD_vid1ask             |                                        |                           |                       |                   |  |  |
|-------------------------------------|----------------------------------------|---------------------------|-----------------------|-------------------|--|--|
| {HLD-0096(0)}                       |                                        | {Covers: }                |                       |                   |  |  |
| {Assignation: PBD} {Test Method: In |                                        | ntegration Test}          | {Integration Phase: } | {Justification: } |  |  |
| Syntax:                             | void                                   | void PBD_vidTask(void)    |                       |                   |  |  |
| Description:                        | Task                                   | Task of the SSD component |                       |                   |  |  |
| Sync/Async:                         | Syncl                                  | Synchronous               |                       |                   |  |  |
| Reentrancy:                         | non r                                  | non reentrant             |                       |                   |  |  |
| Parameters (in):                    | None                                   |                           | None                  | None              |  |  |
| Parameters (out):                   | None                                   |                           | None                  | None              |  |  |
| Return value:                       | None None                              |                           |                       |                   |  |  |
| Caveats:                            | None                                   |                           |                       |                   |  |  |
| Configuration:                      | None                                   |                           |                       |                   |  |  |
| MemSegment:                         | Default compiler memories will be used |                           |                       |                   |  |  |
| MemClass:                           | Default compiler memories will be used |                           |                       |                   |  |  |

| HLI                                                                   | D-0101(0)}                    | {Covers: }            |                   |  |  |  |  |
|-----------------------------------------------------------------------|-------------------------------|-----------------------|-------------------|--|--|--|--|
| {Assignation: PBD}                                                    | {Test Method: Component Test} | {Integration Phase: } | {Justification: } |  |  |  |  |
| The task shall loop on all buttons of the system and check its state. |                               |                       |                   |  |  |  |  |
| {HLI                                                                  | 0-0102(0)}                    | {Covers: SRS-0018(0)} |                   |  |  |  |  |
| {Assignation: PBD}                                                    | {Test Method: Component Test} | {Integration Phase: } | {Justification: } |  |  |  |  |

For HAZZARD\_PB, the press is considered as valid once it's released after being pressed for at least 200 ms. Therefore a transition from HIGH state to LOW state (negative edge) must be detected on the signal PB\_PRESS3 followed by a minimum of 200 ms at the LOW state (signal stabilization time) followed by a transition from LOW state to HIGH state (positive edge).

```
{HLD-0103(0)} {Covers: SRS-0019(0)} {Assignation: PBD} {Test Method: Component Test} {Integration Phase: } {Justification: }
```

For STEP\_DOWN\_PB, the press is considered as valid once it's pressed for at least 10 ms. Therefore a transition from HIGH state to LOW state (negative edge) must be detected on the signal PB\_PRESS1 followed by a minimum of 10 ms at the LOW state (signal stabilization time).

```
 \{ \text{HLD-0104(0)} \} \\ \{ \text{Assignation: PBD} \} \\ \{ \text{Test Method: Component Test} \} \\ \{ \text{Integration Phase: } \} \\ \{ \text{Justification: } \}
```

For STEP\_UP\_PB, the press is considered as valid once pressed for at least 10 ms. Therefore a transition from HIGH state to LOW state (negative edge) must be detected on the signal PB\_PRESS2 followed by a minimum of 10 ms at the LOW state (signal stabilization time).

```
 \{ HLD-0105(0) \} \\ \{ Assignation: PBD \} \\ \{ Test Method: Component Test \} \\ \{ Integration Phase: \} \\ \{ Justification: \} \}
```

If a push button is being pressed, any other push button press shall be ignored.

8.2.2.4.7 Call-backs

None

8.2.2.4.8 Interrupts

#### 8.2.2.5 Component Configuration

None

### 8.3 APP Subsystem

#### 8.3.1 HIF Component

The HIF component is responsible for handling hazard signal application requirements. It only communicates externally with the lower SSD component for the service "SSD\_SetDisplayedNumber".

#### 8.3.1.1 Resources Constraints

None, HIF is on the hardware abstraction layer.

#### 8.3.1.2 External Interfaces (Dependencies)

```
{HLD-0042(0)} {Covers: }
{Assignation: HIF} {Test Method: Static Test} {Integration Phase: } {Justification: }
```

The HIF component shall use the service "SSD\_SetDisplayedNumber" from the SSD component through the inclusion of "SSD\_int.h".

```
{HLD-0043(0)} {Covers: } {Assignation: HIF} {Test Method: Static Test} {Integration Phase: } {Justification: }
```

The HIF component shall include the basic types through the inclusion of "BTY\_int.h".

#### 8.3.1.3 Design Constraints

None

#### 8.3.1.4 Component APIs

8.3.1.4.1 Symbols

None

8.3.1.4.2 Types

None

8.3.1.4.3 Constants

None

8.3.1.4.4 Data

None

#### 8.3.1.4.5 Services

#### 8.3.1.4.5.1 HIF\_vidInit

| {HLD-0044(0)}      |                                 | {Covers: } |                       |                   |  |
|--------------------|---------------------------------|------------|-----------------------|-------------------|--|
| {Assignation: HIF} | {Test Method: Integration Test} |            | {Integration Phase: } | {Justification: } |  |



#### **Induction Training Exercise - HLD Design**

Version 1.3

| Syntax:           | <pre>void HIF_vidInit(void)</pre>      |        |  |  |  |
|-------------------|----------------------------------------|--------|--|--|--|
| Description:      | Initializes the HIF comp               | ponent |  |  |  |
| Sync/Async:       | Synchronous                            |        |  |  |  |
| Reentrancy:       | non reentrant                          |        |  |  |  |
| Parameters (in):  | None None                              |        |  |  |  |
| Parameters (out): | None None                              |        |  |  |  |
| Return value:     | None None                              |        |  |  |  |
| Caveats:          | None                                   |        |  |  |  |
| Configuration:    | None                                   |        |  |  |  |
| MemSegment:       | Default compiler memories will be used |        |  |  |  |
| MemClass:         | Default compiler memories will be used |        |  |  |  |

#### 8.3.1.4.5.2 HIF vidSetMode

| 0.3.1.4.3.2 Till _vid5etiviode |                                        |                                                            |                   |                       |                   |  |
|--------------------------------|----------------------------------------|------------------------------------------------------------|-------------------|-----------------------|-------------------|--|
| {HLD-0045(0)}                  |                                        | {Covers: }                                                 |                   |                       |                   |  |
| {Assignation: HIF}             | {Test Method: Inf                      |                                                            | Integration Test} | {Integration Phase: } | {Justification: } |  |
| Syntax:                        | void                                   | <pre>void HIF_vidSetMode(HIF_tenuMode enuHifSetMode)</pre> |                   |                       |                   |  |
| Description:                   | Sets                                   | Sets the mode of the HIF component                         |                   |                       |                   |  |
| Sync/Async:                    | Syncl                                  | Synchronous                                                |                   |                       |                   |  |
| Reentrancy:                    | non r                                  | non reentrant                                              |                   |                       |                   |  |
| Parameters (in):               | enuH                                   | nuHifSetMode HIF_OFF_MODE HIF_ON_MODE HIF_UNDEFINED_MODE   |                   |                       |                   |  |
| Parameters (out):              | None None                              |                                                            |                   |                       |                   |  |
| Return value:                  | None None                              |                                                            |                   |                       |                   |  |
| Caveats:                       | None                                   |                                                            |                   |                       |                   |  |
| Configuration:                 | None                                   |                                                            |                   |                       |                   |  |
| MemSegment:                    | Default compiler memories will be used |                                                            |                   |                       |                   |  |
| MemClass:                      | Default compiler memories will be used |                                                            |                   |                       |                   |  |

#### 8.3.1.4.6 Tasks

#### 8.3.1.4.6.1 HIF\_vidTask

| {HLD-0046(0)}                      |                           | {Covers: }                        |                       |                   |  |
|------------------------------------|---------------------------|-----------------------------------|-----------------------|-------------------|--|
| {Assignation: HIF} {Test Method: I |                           | ntegration Test}                  | {Integration Phase: } | {Justification: } |  |
| Syntax:                            | void                      | <pre>void HIF_vidTask(void)</pre> |                       |                   |  |
| Description:                       | Task of the HIF component |                                   |                       |                   |  |
| Sync/Async:                        | Synchronous               |                                   |                       |                   |  |
| Reentrancy:                        | non reentrant             |                                   |                       |                   |  |
| Parameters (in):                   | None                      |                                   | None                  |                   |  |



Version 1.3

| Parameters (out): | None None                              |      |  |  |
|-------------------|----------------------------------------|------|--|--|
| Return value:     | None                                   | None |  |  |
| Caveats:          | None                                   |      |  |  |
| Configuration:    | None                                   |      |  |  |
| MemSegment:       | Default compiler memories will be used |      |  |  |
| MemClass:         | Default compiler memories will be used |      |  |  |

 $\{ HLD-0047(0) \} \\ \{ Assignation: HIF \} \\ \{ Test Method: Component Test \} \\ \{ Integration Phase: \} \\ \{ Justification: \} \}$ 

If the system is not in the HAZARD\_BLINK state, the task is responsible to call the SSD interface to command both SSDs with output values LOW to disable both SSDs on board.

 $\{ HLD-0048(0) \} \\ \{ Assignation: HIF \} \\ \{ Test Method: Component Test \} \\ \{ Integration Phase: \} \\ \{ Justification: \} \}$ 

If the system is in the HAZARD\_BLINK state, the task is responsible to call the SSD interface to command both SSDs with output values HIGH to display value 8 on both SSDs for a duration of  $200 \text{ms} \pm 5 \text{ ms}$  and command the output values LOW to disable both SSDs for a duration of  $400 \text{ms} \pm 5 \text{ ms}$ .

#### 8.3.1.4.7 Callbacks

None

8.3.1.4.8 Interrupts

None

#### 8.3.1.5 Component Configuration

None

#### 8.3.2 TIF Component

The TIF component is responsible for handling the turning signals (turn right/left) application requirements. It only communicates externally with the lower SSD component for the service "SSD SetDisplayedNumber".

#### 8.3.2.1 Resources Constraints

None, TIF is on the hardware abstraction layer.

## 8.3.2.2 External Interfaces (Dependencies)

```
 \{ HLD-0050(0) \} \\ \{ Assignation: TIF \} \\ \{ Test \ Method: \ Static \ Test \} \\ \{ Integration \ Phase: \} \\ \{ Justification: \} \\ \}
```

The TIF component shall use the service "SSD\_SetDisplayedNumber" from the SSD component through the inclusion of "SSD\_int.h".

```
 \{ \text{HLD-0051(0)} \} \\ \{ \text{Assignation: TIF} \} \\ \{ \text{Test Method: Static Test} \} \\ \{ \text{Integration Phase: } \} \\ \{ \text{Justification: } \}
```

The HIF component shall include the basic types through the inclusion of "BTY\_int.h".



## 8.3.2.3 Design Constraints

None

8.3.2.4 Component APIs

8.3.2.4.1 Symbols

None

8.3.2.4.2 Types

None

8.3.2.4.3 Constants

None

8.3.2.4.4 Data

None

8.3.2.4.5 Services

#### 8.3.2.4.5.1 TIF vidInit

| 0.3.2.4.3.1 111 _vic |                                        |                           |                       |                   |  |  |  |
|----------------------|----------------------------------------|---------------------------|-----------------------|-------------------|--|--|--|
| {HLD-00              | 052(0)}                                |                           | {Covers: }            |                   |  |  |  |
| {Assignation: TIF}   | {Test                                  | Method: Integration Test} | {Integration Phase: } | {Justification: } |  |  |  |
| Syntax:              | <pre>void TIF_</pre>                   | _vidInit(void)            |                       |                   |  |  |  |
| Description:         | Initializes th                         | e TIF component           |                       |                   |  |  |  |
| Sync/Async:          | Synchronou                             | IS                        |                       |                   |  |  |  |
| Reentrancy:          | non reentra                            | non reentrant             |                       |                   |  |  |  |
| Parameters (in):     | None                                   | None None                 |                       |                   |  |  |  |
| Parameters (out):    | None                                   | None                      |                       |                   |  |  |  |
| Return value:        | None None                              |                           |                       |                   |  |  |  |
| Caveats:             | None                                   |                           |                       |                   |  |  |  |
| Configuration:       | None                                   |                           |                       |                   |  |  |  |
| MemSegment:          | Default compiler memories will be used |                           |                       |                   |  |  |  |
| MemClass:            | Default com                            | piler memories will b     | e used                |                   |  |  |  |

## 8.3.2.4.5.2 TIF\_vidSetMode

| {HLD-0053(0)}      |                                                           |  | {Covers: } |                       |                   |  |
|--------------------|-----------------------------------------------------------|--|------------|-----------------------|-------------------|--|
| {Assignation: TIF} | {Assignation: TIF} {Test Method:                          |  |            | {Integration Phase: } | {Justification: } |  |
| Syntax:            | <pre>void TIF_vidSetMode(TIF_enuMode enuTifSetMode)</pre> |  |            |                       |                   |  |
| Description:       | Sets the mode of the TIF component                        |  |            |                       |                   |  |
| Sync/Async:        | Synchronous                                               |  |            |                       |                   |  |
| Reentrancy:        | non reentrant                                             |  |            |                       |                   |  |





| Parameters (in):  | enuTifSetMode                          | TIF_OFF_MODE TIF_RIGHT_BLINK_MODE TIF_LEFT_BLINK_MODE TIF_UNDEFINED_MODE |  |  |
|-------------------|----------------------------------------|--------------------------------------------------------------------------|--|--|
| Parameters (out): | None                                   | None                                                                     |  |  |
| Return value:     | None                                   | None                                                                     |  |  |
| Caveats:          | None                                   |                                                                          |  |  |
| Configuration:    | None                                   |                                                                          |  |  |
| MemSegment:       | Default compiler memories will be used |                                                                          |  |  |
| MemClass:         | Default compiler memo                  | ries will be used                                                        |  |  |

#### 8.3.2.4.6 Tasks

#### 8.3.2.4.6.1 TIF vidTask

| {HLD-0054(0)} {Covers: } |       |                                                                         |                 |         |  |  |  |
|--------------------------|-------|-------------------------------------------------------------------------|-----------------|---------|--|--|--|
| {Assignation: TIF}       |       | {Test Method: Integration Test} {Integration Phase: } {Justification: } |                 |         |  |  |  |
| Syntax:                  | void  | void TIF_vidTask(void)                                                  |                 |         |  |  |  |
| Description:             | Task  | of the TIF co                                                           | mponent         |         |  |  |  |
| Sync/Async:              | Syncl | hronous                                                                 |                 |         |  |  |  |
| Reentrancy:              | non r | non reentrant                                                           |                 |         |  |  |  |
| Parameters (in):         | None  |                                                                         | None            |         |  |  |  |
| Parameters (out):        | None  |                                                                         | None            |         |  |  |  |
| Return value:            | None  | None None                                                               |                 |         |  |  |  |
| Caveats:                 | None  | None                                                                    |                 |         |  |  |  |
| Configuration:           | None  |                                                                         |                 |         |  |  |  |
| MemSegment:              | Defa  | Default compiler memories will be used                                  |                 |         |  |  |  |
| MemClass:                | Defa  | ult compiler m                                                          | nemories will b | pe used |  |  |  |

{HLD-0055(0)} {Covers: SRS-0032(0)} {Test Method: Component Test} {Integration Phase: } {Justification: }

If the system is in the RIGHT\_BLINK state, the task is responsible to call the SSD interface to command the right SSDs with output values HIGH to display value 8 for a duration of 200ms ± 5 ms and command the output values LOW to disable it for a duration of 300ms ± 5 ms.

> {HLD-0056(0)} {Covers: SRS-0026(0)} {Test Method: Component Test} {Integration Phase: }

If the system is in the RIGHT\_BLINK state, the task is responsible to call the SSD interface to command the left SSD with all values LOW to ensure that the left SSD is not working.

{HLD-0057(0)} {Covers: SRS-0026(0)} {Assignation: TIF} {Integration Phase: } {Test Method: Component Test} {Justification: }

If the system is in the LEFT\_BLINK state, the task is responsible to call the SSD interface to command the left SSDs with output values HIGH to display value 8 for a duration of 200ms ± 5 ms and command the output values LOW to disable it for a duration of 300ms ± 5 ms.

{HLD-0058(0)} {Covers: SRS-0026(0)} {Assignation: TIF} {Test Method: Component Test} {Integration Phase: } {Justification: }

© Valeo Inter-branch Automotive Software

Page 39/48



If the system is in the LEFT\_BLINK state, the task is responsible to call the SSD interface to command the right SSD with all values LOW to ensure that the right SSD is not working.

8.3.2.4.7 Callbacks

None

8.3.2.4.8 Interrupts

None

8.3.2.5 Component Configuration

None

## 8.3.3 MODE Component

The MODE manager is a central component present at the application layer and communicates both vertically and horizontally in the architecture with the TIF, HIF and PBD components to: get the state of the push buttons "PBD\_enuGetButtonState", set the mode of the TIF "TIF\_vidSetMode" and set the mode of the HIF "HIF\_vidSetMode".

#### 8.3.3.1 Resources Constraints

None

## 8.3.3.2 External Interfaces (Dependencies)

 $\{ \text{HLD-0111(0)} \} \\ \{ \text{Assignation: MODE} \} \\ \{ \text{Test Method: Static Test} \} \\ \{ \text{Assignation: MODE} \} \\ \{ \text{Test Method: Static Test} \} \\$ 

The MODE component shall use the service "PBD\_enuGetButtonState" from the PBD component through the inclusion of "PBD\_int.h".

The MODE component shall use the service "HIF\_vidSetMode" from the HIF component through the

inclusion of "HIF\_int.h".

{HLD-0113(0)} {Covers: }
{Assignation: MODE} {Test Method: Static Test} {Assignation: MODE} {Test Method: Static Test}

The MODE component shall use the service "TIF\_vidSetMode" from the TIF component through the inclusion of "TIF\_int.h".

#### 8.3.3.3 Design Constraints

None

#### 8.3.3.4 Component APIs

## 8.3.3.4.1 Symbols

None

8.3.3.4.2 Types

None

8.3.3.4.3 Constants

None

8.3.3.4.4 Data

None

8.3.3.4.5 Services

#### 8.3.3.4.5.1 MODE vidInit

| 0.0.0.T.O.T WODE   | _vidii ii |                                        |                       |                       |                   |  |
|--------------------|-----------|----------------------------------------|-----------------------|-----------------------|-------------------|--|
| {HLD-01            | 114(0)}   |                                        | {Covers: }            |                       |                   |  |
| (Assignation: MODE | }         | {Test Method: In                       | ntegration Test}      | {Integration Phase: } | {Justification: } |  |
| Syntax:            | void      | MODE_vidI                              | <pre>Init(void)</pre> |                       |                   |  |
| Description:       | Initializ | es the MOD                             | E componen            | t                     |                   |  |
| Sync/Async:        | Synchr    | onous                                  |                       |                       |                   |  |
| Reentrancy:        | non ree   | non reentrant                          |                       |                       |                   |  |
| Parameters (in):   | None      | None None                              |                       |                       |                   |  |
| Parameters (out):  | None      | None None                              |                       |                       |                   |  |
| Return value:      | None      | None None                              |                       |                       |                   |  |
| Caveats:           | None      | None                                   |                       |                       |                   |  |
| Configuration:     | None      |                                        |                       |                       |                   |  |
| MemSegment:        | Default   | Default compiler memories will be used |                       |                       |                   |  |
| MemClass:          | Default   | compiler m                             | emories will b        | pe used               |                   |  |

{HLD-0117(0)} {Covers: SRS-0022(0)}

{Assignation: MODE} {Test Method: Component Test} {Integration Phase: } {Justification: }

## Upon startup, this service should put the system in IDLE state.

{HLD-0118(0)} {Covers: SRS-0023(0)}

{Assignation: MODE} {Test Method: Component Test} {Integration Phase: } {Justification: }

Upon startup, both LEFT and RIGHT SSDs should be switched off.

## 8.3.3.4.6 Tasks

#### 8.3.3.4.6.1 MODE\_vidTask

| {HLD-0115(0)}      |           | {Covers: }                         |                  |                       |                   |  |
|--------------------|-----------|------------------------------------|------------------|-----------------------|-------------------|--|
| (Assignation: MODE | }         | {Test Method: I                    | ntegration Test} | {Integration Phase: } | {Justification: } |  |
| Syntax:            | void      | <pre>void MODE_vidTask(void)</pre> |                  |                       |                   |  |
| Description:       | Task      | Task of the MODE component         |                  |                       |                   |  |
| Sync/Async:        | Syncl     | Synchronous                        |                  |                       |                   |  |
| Reentrancy:        | non r     | non reentrant                      |                  |                       |                   |  |
| Parameters (in):   | None      | None None                          |                  |                       |                   |  |
| Parameters (out):  | None None |                                    |                  |                       |                   |  |
| Return value:      | None      |                                    | None             |                       |                   |  |

Version 1.3

| Caveats:       | None                                   |
|----------------|----------------------------------------|
| Configuration: | None                                   |
| MemSegment:    | Default compiler memories will be used |
| MemClass:      | Default compiler memories will be used |

{HLD-0116(0)} {Covers: }

{Assignation: MODE} {Test Method: Component Test} {Integration Phase: } {Justification: }

This task shall grab the state of different push buttons and switch between states accordingly.

{HLD-0119(0)} {Covers: SRS-0025(0)}

{Assignation: MODE} {Test Method: Component Test} {Integration Phase: } {Justification: }

If the system is at the IDLE state and a valid press was detected on STEP\_DOWN\_PB, the system shall go to the LEFT\_BLINK state.

{HLD-0120(0)} {Covers: SRS-0030(0)}

{Assignation: MODE} {Test Method: Component Test} {Integration Phase: } {Justification: }

If the system is at the IDLE state and a valid press was detected on STEP\_UP\_PB, the system shall go to the RIGHT\_BLINK state.

{HLD-0121(0)} {Covers: SRS-0031(0)}

{Assignation: MODE} {Test Method: Component Test} {Integration Phase: } {Justification: }

If the system is at the IDLE state and a valid press was detected on HAZZARD\_PB, the system shall go to the HAZZARD\_BLINK state.

{HLD-0122(0)} {Covers: SRS-0027(0)} {Assignation: MODE} {Test Method: Component Test} {Integration Phase: } {Justification: }

If the system is at the LEFT\_BLINK state and a valid press was detected on STEP\_UP\_PB, the system shall go to the IDLE state.

{HLD-0123(0)} {Covers: SRS-0028(0)}

{Assignation: MODE} {Test Method: Component Test} {Integration Phase: } {Justification: }

If the system is at the LEFT\_BLINK state and a valid press was detected on STEP\_DOWN\_PB, the system shall remain in the LEFT\_BLINK state.

{HLD-0124(0)} {Covers: SRS-0029(0)} {Assignation: MODE} {Test Method: Component Test} {Integration Phase: } {Justification: }

If the system is at the LEFT\_BLINK state and a valid press was detected on HAZZARD\_PB, the system shall go to the HAZARD\_BLINK state.

{HLD-0125(0)} {Covers: SRS-0033(0)}

{Assignation: MODE} {Test Method: Component Test} {Integration Phase: } {Justification: }

If the system is at the RIGHT\_BLINK state and a valid press was detected on STEP\_DOWN\_PB, the system shall go to the IDLE state.

{HLD-0126(0)} {Covers: SRS-0034(0)}

{Assignation: MODE} {Test Method: Component Test} {Integration Phase: } {Justification: }

If the system is at the RIGHT\_BLINK state and a valid press was detected on STEP\_UP\_PB, the system shall remain in the RIGHT\_BLINK state.

{HLD-0127(0)} {Covers: SRS-0035(0)}

{Assignation: MODE} {Test Method: Component Test} {Integration Phase: } {Justification: }

If the system is at the RIGHT\_BLINK state and a valid press was detected on HAZZARD\_PB, the system shall go to the HAZARD\_BLINK state.

{HLD-0128(0)} {Covers: SRS-0037(0)} {Assignation: MODE} {Test Method: Component Test} {Integration Phase: } {Justification: }

If the system is at the HAZZARD\_BLINK state and a valid press was detected on STEP\_UP\_PB or STEP\_DOWN\_PB, the system shall remain in the HAZZARD\_BLINK state.

{HLD-0129(0)} {Covers: SRS-0038(0)}

{Assignation: MODE} {Test Method: Component Test} {Integration Phase: } {Justification: }

If the system is at the HAZZARD\_BLINK state and a valid press was detected on HAZZARD\_PB, the

© Valeo Inter-branch Automotive Software

Page 42/48



system shall go back to its previous state before going to HAZARD\_BLINK state.\*

\* For example if the system was in IDLE state then a valid press was detected on HAZZARD\_PB moving the system to HAZARD\_BLINK state, if another valid press was detected on HAZZARD\_PB the system shall go back to the IDLE state.

8.3.3.4.7 Call-backs

None

8.3.3.4.8 Interrupts

None

## 8.3.3.5 Component Configuration

None

## 8.3.4 SCHED Component

The SCHEDular component is responsible for operating a mini real time system that controls the different tasks through handling the RTC (Real Time Counter) interrupt and running the tasks accordingly. It communicates with MCU, SSD, PBD, MODE, TIF and HIF components as it is present horizontally in the system.

#### 8.3.4.1 Resources Constraints

None

### 8.3.4.2 External Interfaces (Dependencies)

{Assignation: SCHED} {Test Method: Static Test} {Integration Phase: } {Justification: } The SCHED component shall include the microcontroller header file through "mc9s08jm32.h". {HLD-0131(0)} {Covers: } {Assignation: SCHED} {Test Method: Static Test} {Integration Phase: } {Justification: } The SCHED component shall include the basic types through the inclusion of "BTY" int.h.". {HLD-0132(0)} {Test Method: Static Test} {Justification: } {Assignation: SCHED} {Integration Phase: } The SCHED component shall include the compiler types through the inclusion of "CTY" int.h". {HLD-0133(0)} {Covers: } {Assignation: SCHED} {Test Method: Static Test} {Integration Phase: } {Justification: } The SCHED component shall use the service "PBD\_vidTask" from the PBD component through the inclusion of "PBD\_int.h".

{HLD-0134(0)} {Covers: }

{Assignation: SCHED} {Test Method: Static Test} {Integration Phase: } {Justification: } The SCHED component shall use the service "SSD\_vidTask" from the SSD component through the inclusion of "SSD int.h".

{HLD-0135(0)} {Covers: } {Assignation: SCHED} {Test Method: Static Test} {Integration Phase: } {Justification: }

The SCHED component shall use the service "MODE\_vidTask" from the MODE component through the inclusion of "MODE\_int.h".

{HLD-0136(0)} {Covers: } {Test Method: Static Test} {Assignation: SCHED} {Integration Phase: } {Justification: }

The SCHED component shall use the service "HIF\_vidTask" from the HIF component through the inclusion of "HIF\_int.h".

> {HLD-0137(0)} {Covers: }

> > © Valeo Inter-branch Automotive Software

Page 43/48



Version 1.3

{Assignation: SCHED} {Test Method: Static Test} {Integration Phase: } {Justification: }

The SCHED component shall use the service "TIF\_vidTask" from the TIF component through the inclusion of "TIF\_int.h".

## 8.3.4.3 Design Constraints

None

## 8.3.4.4 Component APIs

8.3.4.4.1 Symbols

None

8.3.4.4.2 Types

|                                                      |                                            |                                               | Members                       |  |  |  |
|------------------------------------------------------|--------------------------------------------|-----------------------------------------------|-------------------------------|--|--|--|
| Description                                          |                                            |                                               |                               |  |  |  |
| {HLD-0138(0)}                                        |                                            | {Covers:                                      | }                             |  |  |  |
| {Assignation: SCHED} {Test Method: Integration Test} | Test} {Integration Phase: } {Justification |                                               | {Justification: }             |  |  |  |
| Task Control Block structu                           | ure                                        | pointer a tas<br>task delay (0<br>task period | k to execute ) if not needed) |  |  |  |

8.3.4.4.3 Constants

None

8.3.4.4.4 Data

None

#### 8.3.4.4.5 Services

## 8.3.4.4.5.1 SCHED\_vidInit

| {HLD-0139(0)}                        |         | {Covers: }                          |                  |                       |                   |  |
|--------------------------------------|---------|-------------------------------------|------------------|-----------------------|-------------------|--|
| {Assignation: SCHED} {Test Method: I |         |                                     | ntegration Test} | {Integration Phase: } | {Justification: } |  |
| Syntax:                              | void    | <pre>void SCHED_vidInit(void)</pre> |                  |                       |                   |  |
| Description:                         | Initial | nitializes the SCHED component      |                  |                       |                   |  |
| Sync/Async:                          | Sync    | Synchronous                         |                  |                       |                   |  |
| Reentrancy:                          | non r   | non reentrant                       |                  |                       |                   |  |
| Parameters (in):                     | None    | None None                           |                  |                       |                   |  |
| Parameters (out):                    | None    | None None                           |                  |                       |                   |  |
| Return value:                        | None    | None None                           |                  |                       |                   |  |



| Caveats:       | None                                   |
|----------------|----------------------------------------|
| Configuration: | None                                   |
| MemSegment:    | Default compiler memories will be used |
| MemClass:      | Default compiler memories will be used |

{Integration Phase: } {Assignation: SCHED} {Test Method: Component Test} {Justification: }

The Init function should initialize a local array with the configured values delays for each task and put an initial ACTIVE state for all tasks available.

#### 8.3.4.4.5.2 SCHED vidStartScheduler

| 6.3.4.4.5.2 SUMEL   | J_viuS  | lariochedulei                          |                  |                       |                   |  |  |
|---------------------|---------|----------------------------------------|------------------|-----------------------|-------------------|--|--|
| {HLD-01             | 142(0)} |                                        | {Covers: }       |                       |                   |  |  |
| {Assignation: SCHED | )}      | {Test Method: In                       | ntegration Test} | {Integration Phase: } | {Justification: } |  |  |
| Syntax:             | void    | void SCHED_vidStartScheduler(void)     |                  |                       |                   |  |  |
| Description:        | Starts  | s the main sch                         | neduler of the   | system                |                   |  |  |
| Sync/Async:         | Sync    | hronous                                |                  |                       |                   |  |  |
| Reentrancy:         | non r   | non reentrant                          |                  |                       |                   |  |  |
| Parameters (in):    | None    | None None                              |                  |                       |                   |  |  |
| Parameters (out):   | None    | None None                              |                  |                       |                   |  |  |
| Return value:       | None    | None None                              |                  |                       |                   |  |  |
| Caveats:            | None    | None                                   |                  |                       |                   |  |  |
| Configuration:      | None    |                                        |                  |                       |                   |  |  |
| MemSegment:         | Defa    | Default compiler memories will be used |                  |                       |                   |  |  |
| MemClass:           | Defa    | ult compiler m                         | emories will b   | oe used               |                   |  |  |

{HLD-0143(0)} {Covers: } {Assignation: SCHED} {Test Method: Component Test} {Integration Phase: } {Justification: }

This function shall check the current tick and calls the corresponding task if the task is active.

8.3.4.4.6 Tasks

None

8.3.4.4.7 Call-backs

None

8.3.4.4.8 Interrupts

8.3.4.4.8.1 SCHED vidRtcInterrupt

| o.o.4.4.o.1 Contab_varkontortapt   |                                                                               |                   |                                                       |                   |  |  |  |
|------------------------------------|-------------------------------------------------------------------------------|-------------------|-------------------------------------------------------|-------------------|--|--|--|
| {HLD-0144(0)}                      |                                                                               |                   | {Covers: <covered requirements="" tags="">}</covered> |                   |  |  |  |
| {Assignation: SCHED} {Test Method: |                                                                               | Integration Test} | {Integration Phase: }                                 | {Justification: } |  |  |  |
| Syntax:                            | <cty_interrupt sched_vidrtcinterrupt(void)<="" th="" void=""></cty_interrupt> |                   |                                                       |                   |  |  |  |
| Description:                       | Implementation of the RTC interrupt                                           |                   |                                                       |                   |  |  |  |



Version 1.3

| Sync/Async:       | Synchronous                            |      |  |  |  |
|-------------------|----------------------------------------|------|--|--|--|
| Reentrancy:       | non reentrant                          |      |  |  |  |
| Parameters (in):  | None                                   | None |  |  |  |
| Parameters (out): | None                                   | None |  |  |  |
| Return value:     | None                                   | None |  |  |  |
| Caveats:          | None                                   |      |  |  |  |
| Configuration:    | None                                   |      |  |  |  |
| MemSegment:       | Default compiler memories will be used |      |  |  |  |
| MemClass:         | Default compiler memories will be used |      |  |  |  |

{HLD-0145(0)} {Covers: }
{Assignation: SCHED} {Test Method: Component Test} {Integration Phase: } {Justification: }

This interrupt should increment the tick of the timer that is used by the scheduler to assist it in correctly running the different interrupts on time.

## 8.3.4.5 Component Configuration

| Configuration Pa                                                                           |                                 | Range               | Value               |                   |  |  |  |  |  |
|--------------------------------------------------------------------------------------------|---------------------------------|---------------------|---------------------|-------------------|--|--|--|--|--|
| Description                                                                                |                                 |                     |                     |                   |  |  |  |  |  |
| {HLD-0140(0)}                                                                              |                                 |                     | {Covers: }          |                   |  |  |  |  |  |
| {Assignation: SCHED}                                                                       | {Test Method: Integration Test} |                     | {Integration Phase: | {Justification: } |  |  |  |  |  |
| Tasks Array                                                                                |                                 | 0NumberOfTasks (=5) |                     | N/A               |  |  |  |  |  |
| Array of type "Task Control Block" that defines the different tasks and their periodicity. |                                 |                     |                     |                   |  |  |  |  |  |



# 9 Sequence Management

## 9.1 Initialization Sequence

None

## 9.2 Sequence Diagrams

None



{Assignation: }

Version 1.3

# **10 Software Integration Constraints**

{HLD-0110(0)}

{Test Method: Static Test}

{Covers: SRS-0047(0), SRS-0048(0), SRS-0049(0)} {Integration Phase: } {Justification: }

Refer to section 7 in REF2 for more details.